针对移动设备的CSS3布局
针对移动设备的CSS3布局

一些专业人士预测五年内移动设备将击败普通电脑成为网页浏览领域的霸主,不管这个预言是否应验,让网页在移动设备上较好的显示已经成为网页设计师和开发者的重要任务,本教程学习用CSS3的一些技术来让网页布局适应移动设备。
1、思考
在编写适应移动设备的布局前有几个问题值得思考。
移动互联网浏览
- 限制HTTP请求:3G信号传输费用昂贵,可能的话也要限制图像显示。
- 不同的屏幕尺寸: 移动设备屏幕尺寸宽度一般来说从320到480不等,但是也会因为设备的不同有很大差异,所以在CSS里面预先设定宽度并非明智之举。
- 优化某一类别: 市面上有很多种移动设备以及操作系统、浏览器等,所以优先测试你的访问者用得比较多的设备,现在智能手机一般是iPhone、iPad、黑莓、谷歌Android、塞班Symbian、window等,要根据区域内情况有重点地选择测试。
- 禁用悬停(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><pre> width: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布局的更多相关文章
- web前端学习(三)css学习笔记部分(8)-- SVN的介绍和应用、CSS动画效果、CSS3布局属性全接触
15.SVN的介绍和应用 15.1.SVN的介绍和应用课程概要 将代码进行集中管理,有版本号的进行迭代,方便集体工作的build流程 15.2.SVN的介绍 SVN是Subversion的简称,是一个 ...
- Google 地图 API V3 针对移动设备进行开发
Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...
- 学习笔记 第十一章 CSS3布局基础
第11章 CSS3布局基础 [学习重点] 了解CSS2盒模型. 设计边框样式. 设计边界样式. 设计补白样式. 了解CSS3盒模型. 11.1 CSS盒模型基础 页面中所有元素基本显示形态为方形 ...
- 前端CSS3布局display:grid用法
前端CSS3布局display:flex用法 1. 先附上代码 点击查看代码 <!DOCTYPE html> <html> <head> <meta char ...
- 前端CSS3布局display:flex用法
前端CSS3布局display:flex用法 先附上代码 点击查看代码 <!DOCTYPE html> <html> <head> <meta charset ...
- CSS3基础(3)——CSS3 布局属性全接触
一. 弹性盒模型 1.弹性盒子模型介绍 弹性盒模型(Flexible Box或Flexbox)是一个CSS3新增布局模块,官方称为CSS Flexible Box Layout Module,用于实现 ...
- AIR 3.0针对移动设备的高性能渲染方案
转自:http://blog.domlib.com/articles/242.html 当我们一边正在等待Stage3D的发布时,很多开发者似乎还停留在这个印象中:即使AIR 3.0也无法在移动设备上 ...
- 说说css3布局
使用float属性或position属性布局的缺点 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml&qu ...
- Flex:CSS3布局利器
实习以来做了三个小控件,都是用的CSS2.1里传统的DIV+CSS布局方式,综合使用position.margin.float.BFC等属性或特性将元素放到指定的位置上.然而面对日益复杂的界面,这些来 ...
随机推荐
- 测试bug
模板在运行时出现了以下 1 个错误:---------------------------Controller.tt(-1,-1) : error : 获取 AppDomain 以便从主机运行转换时出 ...
- DB2 日志
跟Oracle类似DB2也分为两个模式,日志循环vs归档日志,也就是非归档和归档模式,下面对这两种模式做简单的介绍. 日志循环 日志循环是默认方式,也就是非归档模式,这种模式只支持backup off ...
- 在.net项目中使用Consul
1.创建.net core web程序并运行 2.在Consul中注册该服务 Consul支持两种服务注册的方式,一种是通过Consul的服务注册HTTP API,由服务自身在启动后调用API注册自己 ...
- CentOS 7 U盘安装问题解决
最近期待以久的CentOS 7正式版终于发布了,在家里无聊,所以就打算在我的小Y上安装一下,由于笔记本原来有安装Windows 7 操作系统,考虑使用的需求,所以决定安装双系统: 1. ...
- 使用nginx反向代理时,如何正确获取到用户的真实ip
在记录日志的的时候,获取用户的信息,比如用户的ip,浏览器等等信息是十分重要的. 但是在使用nginx反向代理的时候,可能经过转发无法获取到用户的真实的ip, 在此情况下需要配置nginx,让其在转发 ...
- C#使用 SharpSSH
准备试一把监控Linux机器 . 附件如下 :http://files.cnblogs.com/files/lclblog/Tamir.SharpSsh.zip
- 【bzoj2257】[Jsoi2009]瓶子和燃料 扩展裴蜀定理+STL-map
题目描述 给出 $n$ 个瓶子和无限的水,每个瓶子有一定的容量.每次你可以将一个瓶子装满水,或将A瓶子内的水倒入B瓶子中直到A倒空或B倒满.从中选出 $k$ 个瓶子,使得能够通过这 $k$ 个瓶子凑出 ...
- 运维朋友们,别再问需不需要学 Python 了!
运维人员需不需要学开发?需不需要学 Python?PythonN 和 Shell 有什么区别?天天问这种好水的问题,我实在受不了,决定帮大家扫扫盲. 现阶段,掌握一门开发语言已经成为高级运维工程师的必 ...
- Zookeeper(四)Hadoop HA高可用集群搭建
一.高可就集群搭建 1.集群规划 2.集群服务器准备 (1) 修改主机名(2) 修改 IP 地址(3) 添加主机名和 IP 映射(4) 同步服务器时间(5) 关闭防火墙(6) 配置免密登录(7) 安装 ...
- 浴谷金秋线上集训营 T11738 伪神(树链剖分)
先树链剖分,一棵子树的编号在数组上连续,一条链用树链剖分,把这些线段全部取出来,做差分,找到有多少点被>=t条线段覆盖即可. #include<iostream> #include& ...