html css页面顶端设计,网页布局之响应式设计简明指南

一、为什么要使用响应式设计?

f0ecec18e6e1d00a549040a2a472868f.png

我们想让我们的网站通过响应用户的行为、设备的屏幕大小和屏幕方向,从而在所有设备上都能用。

二、一个碎片化的世界

截止2013年,有成千上万种不同的设备在浏览网页,所以我们不可能设计出适应所有屏幕大小的网页。相反,我们必须得采用一种更加流畅的方式去设计。

三、移动优先

最近一个比较火的词叫移动优先。它的意思是,先为移动端设计样式,然后再根据需求去优化更大屏幕的样式。换句话说,假如你把移动端样式当成网站的默认样式,且以后不用去优化它,一步到位。那就更省事了!

复制代码代码如下:

”假定默认使用一个灵活但简单的布局,你的确可以适配各种浏览器,但这还不算是完全做到了响应式布局。所以当我们谈论「移动优先」,实际上是在说「渐进增强」。“

—Ethan Marcotte

6414afe982c45e9e7a30ab2b5f8ab217.png

四、用 Min-width 进行媒体查询( Media Queries )

现在来介绍一种特别的布局方式。 通过 min-width 来界定不同屏幕该如何布局。它能就近检测出不同设备的屏幕大小(即 media queries,可直译为媒体查询),比在样式表末尾或一个单独文件中处理更简单。

复制代码代码如下:

/* Small screens (default) */

html { font-size: 100%; }

/* Medium screens (640px) */

@media (min-width: 40rem) {

html { font-size: 112%; }

}

/* Large screens (1024px) */

@media (min-width: 64rem) {

html { font-size: 120%; }

}

1、不是所有浏览器生而平等

同一份 CSS,不同浏览器渲染出来的效果不一样。为了避免出现这种情况,你可以使用类似 Normalize.css 这种更好的 CSS 来帮助你实现跨浏览器显示。当然,你要把这份CSS放在你样式表最前面。

复制代码代码如下:

2、在 Viewport 里加 Meta 标签

在你 HTML 的

代码里添加 Meta 标签。它可以使 media queries 在不同设备上起作用

复制代码代码如下:

3、CSS 盒模型

基础很重要!在深入响应式设计之前,最好把像 HTML 元素如何在浏览器中生成并渲染这类知识搞清楚。CSS 盒模型由以下四部分组成。

dd7bbbf6ef472015f8e45cede848090f.png

4、设置 box-sizing: border-box

在 CSS 文件最顶端设置 box-sizing。运用 * 通用选择器使其应用到页面的每个元素上。

复制代码代码如下:

*, *:before, *:after {

-moz-box-sizing: border-box;

-webkit-box-sizing: border-box;

box-sizing: border-box;

}

5、你的选择

CSS 有个常见 BUG。是否设置 box-sizing,将意味着 border 和 padding 的值是否计算在 width 之内。

3e6052686cc77168b808bdb054462a94.png

6、创建容器

一个容器将包含页面所有标签,并控制页面最大宽度. 运用容器,让我们的响应式设计更进了一步!

复制代码代码如下:

.container {

margin: 0 auto;

max-width: 48rem;

width: 90%;

}

4a5f0f901a7808e795d0303dab147773.png

7、创建列

在移动优先里,列默认均是 block 级别的(可以占满整行的宽度)。不需要额外的样式!

复制代码代码如下:

f428a773d53a2ca83ed86f13dcc215b9.png

8、创建列宽

在大屏中,用 float: left 将列水平排列。然后运用 padding 设置相邻两列之间的间隙,忘掉传统的margin吧。

8edcbb9e4d6d822dfed6de2d2e18105f.png

复制代码代码如下:

@media (min-width: 40rem) {

.column {

float: left;

padding-left: 1rem;

padding-right: 1rem;

}

.column.full { width: 100%; }

.column.two-thirds { width: 66.7%; }

.column.half { width: 50%; }

.column.third { width: 33.3%; }

.column.fourth { width: 25%; }

.column.flow-opposite { float: right; }

}

00514eefeec1024d0e7dbe520301ae1a.png

9、创建行

列应该包裹在行内,以避免其他元素堆放在其旁边造成布局混乱。否则就会出现广为人知的 clearing 问题。出现之后可以使用由 Nicolas Gallagher 发明的 clearfix 解决。

复制代码代码如下:

.clearfix:before,

.clearfix:after {

content: " ";

display: table;

}

.clearfix:after {

clear: both;

}

.clearfix {

*zoom: 1;

}

7181dce40720de3dcb0f349aa885ca4e.png

10、相对流( Flow Opposite )

给你想让它在移动端优先显示,而在大屏幕中右侧显示的列,添加 .flow-opposite 类。

复制代码代码如下:

@media (min-width: 40rem) {

.column.flow-opposite { float: right; }

}

64c125f8d1f16e56a0f07d6c36606e1c.png

五、熟能生巧

通过这些简单的步骤,你已经走上了响应式设计之路。坚持练习,会让你的网页更好更实用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值