针对移动设备的CSS3布局

一些专业人士预测五年内移动设备将击败普通电脑成为网页浏览领域的霸主,不管这个预言是否应验,让网页在移动设备上较好的显示已经成为网页设计师和开发者的重要任务,本教程学习用CSS3的一些技术来让网页布局适应移动设备。

1、思考

在编写适应移动设备的布局前有几个问题值得思考。

移动互联网浏览

  1. 限制HTTP请求:3G信号传输费用昂贵,可能的话也要限制图像显示。
  2. 不同的屏幕尺寸: 移动设备屏幕尺寸宽度一般来说从320到480不等,但是也会因为设备的不同有很大差异,所以在CSS里面预先设定宽度并非明智之举。
  3. 优化某一类别: 市面上有很多种移动设备以及操作系统、浏览器等,所以优先测试你的访问者用得比较多的设备,现在智能手机一般是iPhone、iPad、黑莓、谷歌Android、塞班Symbian、window等,要根据区域内情况有重点地选择测试。
  4. 禁用悬停(Hover): 触摸屏并不能很好地支持hover,所以做菜单时,最好不要使用下拉菜单等形式,hover在移动设备上一般来说只能用于增加视觉的效果(比如更改颜色)。

浏览器支持(桌面平台)

其次,记住要跨浏览器支持,谚语有云“房间里的大象(译者注:英文谚语,指显而易见而又被忽略的事实)指的就是IE。幸运的是,现在发现,只要不会
影响到内容,网站在不同浏览器的显示不一定要完全相同。通常来说一个无法支持CSS3的浏览器也能提供尚可接受的浏览体验。总而言之,要提前知道网页在各
种浏览器上的显示效果。

2、HTML

Body部分

不仅应该知道如何编写合法的html,而且要尽可能地简洁。保持html的流畅、去掉不必要的Div一直都是不错的习惯,在移动设备浏览上,这点显得更为重要。而且,以往一些需要7个嵌套Div标记的效果,现在通过CSS3的少量代码就能实现。

尽管这不是html5教程,但是我依然坚持Xhtm的严格语法。以下是一个典型布局的html,这是一个包含头部、底部、侧边栏、主内容的页面。你可以看到,这个页面相当简单明了,如果采用html5的元素,能够更加的简洁。

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<body>
  <div class='pg'>
    <div class='head'>
      <h1><a href='#'>My Blog</a></h1>
    </div>
 
    <div class='pg-main'>
 
      <div class='entries'>
        <h2><a href='#'>An Entry About Something</a></h2>
        <p class='preview'>段落文字一前言</p>
        <p>段落文字一</p>
        <hr/>
 
        <h2><a href='#'>An Entry About Something Else</a></h2>
        <p class='preview'>段落文字二前言</p>
        <p>段落文字二</p>
        <hr/>
 
        <h2><a href='#'>A Third Entry</a></h2>
        <p class='preview'>段落文字三前言</p>
        <p>段落文字三</p>
      </div>
 
      <div class='sidebar'>
        <h2 class='not-there'>Blog Menu</h2>
        <h3 class='subscribe'>Subscribe</h3>
        <ul class='subscribe'>
          <li><a href='#'>RSS</a></li>
        </ul>
        <h3>Social</h3>
        <ul>
          <li><a href='#'>Facebook</a></li>
          <li><a href='#'>Twitter</a></li>
        </ul>
        <h3>Categories</h3>
        <ul>
          <li><a href='#'>Something</a></li>
          <li><a href='#'>Nothing</a></li>
          <li><a href='#'>All Things</a></li>
          <li><a href='#'>No Things</a></li>
        </ul>
        <h3>Archives</h3>
        <ul>
          <li><a href='#'>June 2010</a></li>
          <li><a href='#'>May 2010</a></li>
          <li><a href='#'>April 2010</a></li>
          <li><a href='#'>March 2010</a></li>
        </ul>
      </div>
    </div>
 
    <div class='foot'>
      <p>© No one in particular 2010</p>
    </div>
 
  </div>
</body>;

Meta标记:Viewport

在head部分,一般会放置例如CSS样式表、语言、标题等等,但是为了平滑移动设备浏览器效果,还需要而外增加一个Viewport,参考代码如下:

1
<meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=0;"/>

这是苹果公司建议的,用于帮助iPhone渲染页面,这个标记会自动匹配页面和浏览器窗口并防止缩放,一些其他的移动浏览器也支持,如黑莓。测试发现,这个标记并不会影响到桌面平台浏览器的效果,所以建议放置在head里面。

思考布局

这个教程会将以上的html分成两个布局,一个布局用来适应移动平台,一个用来适应桌面平台。在实践中,通常要根据目标的不同,分开弄几个布局,这里为了简化教程,只分为两个。

3、针对移动平台

本教程的目的不在于富文本技术或者页面设计,所以,呈现的效果会比较简陋,不过这并不重要,重要的是驾驭样式表的思路。一切的要点在于优先考虑移动平台的布局,因为一个在移动平台上显示正常的布局很可能也能适应桌面平台。所以要先从移动平台的布局弄起,这能够确保在移动平台统治的趋势下,你的网站不会丢失听众。

CSS参考

先思考一下,要避免出现很长的滚动条,所以修改一下博客的菜单,让用户体验更好。

1
2
3
4
5
6
7
8
9
.sidebar ul{
  border-left:solid 1px #ccc;
  padding:0 0 0 5px;
}
.sidebar ul li{
  display:inline;
  padding:0 5px 0 0px;
  border-right:solid 1px #ccc;
}

这样菜单就变成横排的,每个目录中间有一条分割线,干净整洁。在移动设备上,保持菜单在屏幕底部是非常有用的,假如浏览完一篇文章,菜单不在底部的话,还要再滚动回菜单的地方,这样就很不方便,在一些设备上,滚动窗口可能会相对麻烦得多。当然这个方式有利有弊。

其次将RSS订阅移动到顶部区域。

01
02
03
04
05
06
07
08
09
10
11
12
13
h3.subscribe{
  display:none;
}
.sidebar ul.subscribe{
  position:absolute;
  top:25px;
  right:10px;
  border:none;
  color:#fff;
}
.sidebar ul.subscribe li{
  border:none;
}

除此之外,就是调整一些字体的大小,超链接的颜色等,此教程还包含一个CSS Reset,完整的CSS可以在源码上找到。因此,其实如果站在移动设备优先的角度上思考的话,布局的时候也没什么特别之处。

4、针对桌面平台

介绍:媒介查询Media Query

通过CSS3的媒介查询,跨设备的问题能够较好地解决。媒介查询可以根据若干个条件(比如屏幕尺寸),使页面对移动设备进行匹配,

先看一下下面的代码:

1
2
3
4
.pg{</span>
<prewidth:800px;
  margin:0 auto;
}

在这个例子中,宽度是800px,但是这样必须确保所有用户的浏览器窗口宽度都是至少800px,否则就会出现水平滚动条。所以将这条代码放置在媒介查询里面,代码如下:

1
2
3
4
5
6
@media all and (min-width:800px){</span>
<pre>  .pg{
    width:800px;
    margin:0 auto;
  }
}

这样事情变得很简单,代码中“all”意味着这个style可用于所有的媒介,还有其他选项,比如“print”则适用于打印机

操作:覆盖”之前的样式

有一个重要的地方需要注意的是,保留原来布局样式的代码,将新布局的样式代码放置在媒介查询中,这样一些不支持CSS3媒介查询的浏览器就可以调用之前的布局,同时桌面平台上一些较老的浏览器的显示也不会有什么大问题。

以下例子,在新布局中,我们将侧边栏从底部移开,并让list的部分以列表的形式显示。代码如下:

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
@media all and (min-width:800px){
  .sidebar ul{
    border:none;
    padding:0;
  }
  .sidebar ul li{
    display:block;
    padding:0;
    border:none;
  }
  h3.subscribe{
    display:block;
  }
  .sidebar ul.subscribe{
    position:static;
    top:auto;
    right:auto;
    border:inherit;
    color:inherit;
  }
  .sidebar ul.subscribe li{
    border:inherit;
  }
}

这样就吧侧边栏推到左边(结合css其他代码,请参阅源文件),并把RSS订阅放回到适用于桌面浏览器显示的地方。你可以用不同平台浏览器打开源文件,并水平缩放,进行测试。

也许有人会疑惑为什么是800px,800px是否有什么特殊之处?事实上,我认为这有点宽。在新发布的windows7上有一个屏幕边缘捕捉的功
能(译者注:就是把窗口拉到两边,会把窗口的缩放成屏幕的一半,拉到顶上会最大化),如果把为桌面平台显示的网站宽度设成600px,这样一个在
1280px宽的屏幕下,捕捉到边缘时不需要调整窗口大小就能正常显示布局。当然这只是一个例子而已,只是要清楚800px并不意味着什么特殊值,一切都
要根据自己的需要去思考。

5、可替代的方法

方法不止一种,本文展示了媒介查询这种实用方法以及一些只基于CSS的移动平台网站布局的办法。还有以下的方法可以联合使用,打造移动平台的网站布局。

  • 多个模板: 制作不同的模板,然后主题系统检测用户浏览器,根据不同浏览器显示不同的主题。这通常是也可以通过制作几个不同的CSS文件来实现。
  • 子域名: m., mobile., 和 .mobi有成为标准的趋势, 不同子域名有不同内容, 在避免内容重复上,和多个模板的技术差不多。
  • 可变的布局: 网站也能够设计成完全可变布局,无论浏览器窗口的大小,内容会自动适应。事实上,在这个教程里,适用于移动平台的样式表,就是可变的布局,使用媒介查询的方式好处在于可以复制背景并降低HTTP请求。

处理移动互联网浏览的方式很多,最终可能是多种方式联合使用。无论是是使用媒介查询或者子域名转向的方式,要点在于提前对移动平台的布局进行规划。

针对移动设备的CSS3布局的更多相关文章

  1. web前端学习(三)css学习笔记部分(8)-- SVN的介绍和应用、CSS动画效果、CSS3布局属性全接触

    15.SVN的介绍和应用 15.1.SVN的介绍和应用课程概要 将代码进行集中管理,有版本号的进行迭代,方便集体工作的build流程 15.2.SVN的介绍 SVN是Subversion的简称,是一个 ...

  2. Google 地图 API V3 针对移动设备进行开发

    Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...

  3. 学习笔记 第十一章 CSS3布局基础

    第11章   CSS3布局基础 [学习重点] 了解CSS2盒模型. 设计边框样式. 设计边界样式. 设计补白样式. 了解CSS3盒模型. 11.1  CSS盒模型基础 页面中所有元素基本显示形态为方形 ...

  4. 前端CSS3布局display:grid用法

    前端CSS3布局display:flex用法 1. 先附上代码 点击查看代码 <!DOCTYPE html> <html> <head> <meta char ...

  5. 前端CSS3布局display:flex用法

    前端CSS3布局display:flex用法 先附上代码 点击查看代码 <!DOCTYPE html> <html> <head> <meta charset ...

  6. CSS3基础(3)——CSS3 布局属性全接触

    一. 弹性盒模型 1.弹性盒子模型介绍 弹性盒模型(Flexible Box或Flexbox)是一个CSS3新增布局模块,官方称为CSS Flexible Box Layout Module,用于实现 ...

  7. AIR 3.0针对移动设备的高性能渲染方案

    转自:http://blog.domlib.com/articles/242.html 当我们一边正在等待Stage3D的发布时,很多开发者似乎还停留在这个印象中:即使AIR 3.0也无法在移动设备上 ...

  8. 说说css3布局

    使用float属性或position属性布局的缺点 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml&qu ...

  9. Flex:CSS3布局利器

    实习以来做了三个小控件,都是用的CSS2.1里传统的DIV+CSS布局方式,综合使用position.margin.float.BFC等属性或特性将元素放到指定的位置上.然而面对日益复杂的界面,这些来 ...

随机推荐

  1. VK Cup 2015 - Round 2 (unofficial online mirror, Div. 1 only) B. Work Group 树形dp

    题目链接: http://codeforces.com/problemset/problem/533/B B. Work Group time limit per test2 secondsmemor ...

  2. Geek荣耀大会总结

    0.0 首先没有被抽中, 其次可乐真难喝,再次我没有去拍无人机合影,再再次还是很受打击的. 1.0 其实 对geek 和1024大会无感,主要原因 没有三倍加班费的节日在我眼里都不是节日. 上面只是简 ...

  3. Laravel 5.4 数据库迁移一次之后就不起作用!

    https://segmentfault.com/q/1010000010806351 我在命令行中生成了一个新的迁移脚本: 当我执行命令:php artisan migrate 时 显示迁移成功,并 ...

  4. Kafka生产者各种启动参数说明

    首先是启动一个生产者 final String kafkazk="localhost:9092"; String topic="testAPI"; Proper ...

  5. 方法调用时候 传入this 谁调用 传入谁

    方法调用时候 传入this 谁调用 传入谁

  6. BZOJ3711 PA2014Druzyny(动态规划+cdq分治+线段树)

    显然可以dp:设f[i]为前i个人最多能分多少组,则f[i]=max{f[j]}+1 (cmax<=i-j<=dmin). 容易发现d的限制是一段连续区间,二分或者随便怎么搞都行.c则有点 ...

  7. 吉哥系列故事――完美队形II HDU - 4513(马拉车变一下形)

    题意: 求最长回文串...但这个回文串要符合从中间到两头 逐个递减 解析: 在扩散的时候加一个判断就好了 #include <iostream> #include <cstdio&g ...

  8. QT 选择对话框简单示例

    QT 选择对话框简单示例 部分代码: pDialog->addSeparator(); QAction *pmb2 = pDialog->addAction(QString::fromLo ...

  9. 卷积 & 杜教筛

    目录 卷积 杜教筛 前言:发现最近都没怎么写博客,,,赶紧发篇以前记的笔记凑凑数 卷积 卷积定义: 如果有数论函数\(f, g\), 那么它们卷积的第\(n\)项为\((f * g) (n)\),设这 ...

  10. 代码收藏系列--php--加载sql文件并解析成数组

    php加载sql文件,解析成以分号分割的数组.(支持存储过程和函数提取,自动过滤注释) /** * 加载sql文件为分号分割的数组 * <br />支持存储过程和函数提取,自动过滤注释 * ...