响应式设计简易指南
Made by Adam Kaplan. 译者 GeekPlux
我们想让我们的网站通过响应用户的行为、设备的屏幕大小和屏幕方向,从而在所有设备上都能用。
截止2013年,有成千上万种不同的设备在浏览网页,所以我们不可能设计出适应所有屏幕大小的网页。相反,我们必须得采用一种更加流畅的方式去设计。
最近一个比较火的词叫移动优先。它的意思是,先为移动端设计样式,然后再根据需求去优化更大屏幕的样式。换句话说,假如你把移动端样式当成网站的默认样式,且以后不用去优化它,一步到位。那就更省事了!
”假定默认使用一个灵活但简单的布局,你的确可以适配各种浏览器,但这还不算是完全做到了响应式布局。所以当我们谈论「移动优先」,实际上是在说「渐进增强」。“
—Ethan Marcotte
现在来介绍一种特别的布局方式。 通过 min-width
来界定不同屏幕该如何布局。它能就近检测出不同设备的屏幕大小(即 media queries,可直译为媒体查询),比在样式表末尾或一个单独文件中处理更简单。
同一份 CSS,不同浏览器渲染出来的效果不一样。为了避免出现这种情况,你可以使用类似 Normalize.css 这种更好的 CSS 来帮助你实现跨浏览器显示。当然,你要把这份CSS放在你样式表最前面。
在你 HTML 的<head>
代码里添加 Meta 标签。它可以使 media queries 在不同设备上起作用
基础很重要!在深入响应式设计之前,最好把像 HTML 元素如何在浏览器中生成并渲染这类知识搞清楚。CSS 盒模型由以下四部分组成。
盒子中的内容,可以是文本也可以是图片等。
内容外围的一圈空白。
内边距外围的一条边框。
边框外围的一圈空白。
在 CSS
文件最顶端设置 box-sizing。运用 *
通用选择器使其应用到页面的每个元素上。
CSS 有个常见 BUG。是否设置 box-sizing,将意味着 border 和 padding 的值是否计算在 width 之内。
Margin, borders and padding 均不包含在内容宽度之内。
Borders and padding 均包含在内容宽度之内。margin 在外单独计算。
一个容器将包含页面所有标签,并控制页面最大宽度. 运用容器,让我们的响应式设计更进了一步!
在移动优先里,列默认均是 block
级别的(可以占满整行的宽度)。不需要额外的样式!
在大屏中,用 float: left
将列水平排列。然后运用 padding 设置相邻两列之间的间隙,忘掉传统的margin吧。
列应该包裹在行内,以避免其他元素堆放在其旁边造成布局混乱。否则就会出现广为人知的 clearing 问题。出现之后可以使用由
Nicolas Gallagher
发明的 clearfix
解决。
给你想让它在移动端优先显示,而在大屏幕中右侧显示的列,添加 .flow-opposite
类。