教你如何玩转Web响应式布局

最初接触的第一个项目是类似于 Jira 的基于Web 的项目管理网站,其中让人印象深刻的是这个网站的用户是公司的内部员工,它的设计都是固定的宽度(960px),而这种宽度设计在员工的笔记本上显示得刚好。

由于公司期望给所有终端用户最为一致的用户体验,取决于这种设计目的,我们用一个固定的宽度恰好合适,但是这种宽度设计在高分辨率显示器,小屏幕设备(上网本等),甚至是移动端的产品上显然是不合适的。

透过这件事,我们网页开发者在进行网页开发的时候会有以下两种选择:

针对每种设备开发一套网站

开发一个网站适配所有设备


显然前者并不是一个明智的选择,但幸运的是,现在我们可以采用响应式网页设计来实现所有网站的适配,做一个网站同时能兼容各种设备和屏幕。

什么是响应式设计?

响应式网页设计:由 Ethan Marcotte 提出,Ethan Marcotte在 A List Apart 发表了一篇开创性的文章,将三种已有的开发技巧(弹性网格布局弹性图片媒体和媒体查询)整合起来,并命名为响应式网页设计。

真正的响应式设计方法不是根据视口大小改变网页布局,恰巧相反,它是从整体上颠覆我们当前设计网页的方法。从前我们针对电脑进行固定宽度设计,然后将其缩小并针对小屏幕进行内容重排 ;而现在,我们采用的方式是先针对小屏幕进行设计,进而逐步增强针对大屏幕的设计与内容。

1)浏览器

浏览器是所有页面的容器或者说运行环境,所有的网页都是跑在浏览器上面,对浏览器的了解是进行网页设计的第一步。

在电脑上,我们通常用的有5种浏览器,而手机上,浏览器则有30种之多。很多的浏览器并非完全独立的浏览器,其中很多都只是基于同一浏览器的不同版本,尤其是安卓 WebKit。

手机上有4种浏览器类型:内置浏览器可下载浏览器代理浏览器,以及WebView

按照目前的市场份额,安卓和 IOS 占领了移动端大部分的江山。所以,我们在做响应式设计的时候需要保证安卓和 IOS上面能跑,然后再根据实际情况和成本考虑是否适配其他的浏览器。

2)视口

响应式设计的另一个重点就是视口。视口和设备的屏幕尺寸不是同一个概念。视口是指浏览器窗口内的内容区域,不包含工具栏,标签栏等,也就是网页实际显示的区域。

屏幕尺寸是设备的物理显示区域。在桌面浏览器中,只有一个视口也就是浏览器窗口。在移动端,有下面三个视口:

布局视口:与移动端浏览器屏幕宽度不关联,完全独立的,仅仅限制 CSS的布局。

视觉视口:用户看到网站的区域,用户可以通过缩放来操作视觉视口。

理想视口:苹果公司最先引入的一种对设备来说最理想的布局视口尺寸,拥有最理想的浏览和阅读宽度。

响应式设计的基础就是把布局视口的尺寸设置为理想视口。

3)媒体查询


(设置竖屏时背景为浅蓝色)

媒体查询就是 CSS 中的 if 语句,可以让我们根据设备显示器的特性设置特定的CSS 样式。使用媒体查询,几行代码就可以根据诸如视口宽度,屏幕比例,设备方向等特性来改变页面内容的显示方式。

4) HTML5 和 CSS3

响应式设计的一个主要目标是,网站不仅要对用户有限的视口做出响应,还要以最快的时间加载网页。

HTML5   强调简化标签,仅链接那些我们必须的 CSS,JS 和图片文件。

CSS3     是在 CSS2 的基础上追加的新功能,提供了动画,渐变等特效,并且提供了很多新特性。

使用 HTML5 和 CSS3,允许我们用最简洁和快速的代码创建一些相对复杂的页面,而不是所有的都依赖 JS 和图片。

如何做响应式设计?

1)先设置视口

这段代码的意思如下:

(width=device-width)网页宽度默认等于屏幕宽度

(initial-scale=1.0)原始缩放比例为1.0,即网页初始大小占屏幕面积的100%

(maximum-scale)定义放大最大比例为1

(user-scalable=no)     定义是否允许用户手动缩放页面,默认为YES

2)百分比搭配媒体查询

在最初使用媒体查询的时候,你会觉得它功能强大无比。但随着项目越做越多你会发现媒体查询只是一个必要条件。如果只使用媒体查询来适应不同视口的固定宽度设计,只会从一组 CSS 媒体查询规则变到另一组,两者之间没有任何平滑渐变。

我们需要的是一个灵活的设计,能在所有视口中都完美的显示,而不仅仅针对媒体查询设置的固定视口。

合理使用百分比布局创建流动的弹性界面,同时使用媒体查询来限制元素的变动范围,基于以上两者我们才能构建出完美的设计。

3)em,rem

px是最常用的长度单位,它是一种相对长度单位,代表像素,它取决于显示设备的分辨率。

em是常用的印刷度量单位,在CSS里面,1个 em 定义为一种给定字体的font-size 值,如果一个元素的 font-size 是16px,那么对于该元素,1em 就等于16px。

rem 是指相对于根元素字体大小的单位。

如果我们给 body 标签设置文字大小为100%,给其他的文字都使用相对单位rem,那这些文字都会受 body 上的初始声明的影响,这样做的好处是如果以后需要改变文字的大小,我们只用修改 body 的文字大小,其他的所有文字都会依照比例相应改变。

4)弹性图片

要实现图片随流动布局相应缩放,只需给在CSS中给图片添加 width 百分比。如果包含块里面就只有图片可以设置为100%。

如果包含块有其他元素,这将会引入一个问题,缩放则会影响到它的包含块以及其他元素。所以我们需要给特定图片设置特定的规则,如果图片拉伸超过了图片的原始尺寸,图片的显示就会有问题。我们也需要给图片设置max-width一个阙值。

图片缩放的问题:图片的尺寸必须比其显示尺寸更大,这样才能保证渲染效果。基于这个原因,图片文件的体积比实际显示的图片更大。如果要做大最好,也可以考虑为不同的屏幕尺寸提供不同的图片。

响应式设计的未来—Flexbox

Flexbox 也可以叫弹性布局,是CSS3新出的一种布局方式,也是 CSS3 推荐使用的一种布局方法,但并不能支持所有的浏览器。


如图所示,IE系列只有 IE11+ 支持 Flexbox,移动端大部分已支持 Flexbox。

总结

最后,举个栗子,如下是一个实际的基于百分比,媒体查询的响应式网页:


该例子中的网页可以适配PC 端和移动端,但是它的实际应用场景主要为移动端。所以当我们在做开发和设计的时候也得多多思考,突破原有的思维定式,去考虑一个网站是否需要在所有浏览器中表现一致。

以上,大致介绍了我在工作中应用的响应式方面的知识以及自己的一些想法。然而响应式设计还有很多更细致的内容,从弹性网格布局到 rem 再到 flex,这些知识点我将在以后为大家讲述。

本文作者:谢宗匠(点融黑帮),就职于点融网Client Team,喜欢码各种代码,目前在做前端开发。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容