响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。简单理解就是可以让一个网站兼容多个终端,而不是为每个终端做一个特定的版本,响应式设计是移动设备快速崛起下的产物,这个概念就是为了解决移动互联网而诞生的。大部分响应式网页都是通过媒体查询,根据不同的媒体设备从而加载不同样式的 CSS 文件来实现的。

1、响应式 Web 设计 - Viewport

  (1)、什么是 Viewport?

  viewport 翻译为中文为"视区/视窗/视口",就是指用户网页的可视区域。手机浏览器是把页面放在一个虚拟的 viewport 中,通常这个虚拟的 viewport 比屏幕宽,这样就不用把每个网页挤到很小的窗口中,这样会破坏没有针对手机浏览器优化的网页的布局,用户可以通过平移和缩放来查看网页的不同部分。

  (2)、设置 Viewport

  一个常用的针对移动网页优化过的页面的 viewport <meta> 元素大致如下:

<meta name="viewport" content="width=device-width,height=device-height,inital-scale=1.0,maximum-scale=1.0,user-scalable=no;" />

  代码解析:

  width:控制 viewport 的大小,可以是指定的一个值,比如 1920,或者是特殊的值,如 device-width 为设备的宽度,单位为缩放为 100% 时的 CSS 的像素。

  height:和 width 相对应,指定高度,可以是指定的一个值,比如 1080,或者是特殊的值,如 device-height 为设备的高度。

  initial-scale:初始缩放比例,即当页面第一次载入是时缩放比例。

  maximum-scale:允许用户缩放到的最大比例。

  minimum-scale:允许用户缩放到的最小比例。

  user-scalable:用户是否可以手动缩放。

2、 响应式 Web 设计 - CSS 栅格系统

  (1)、什么是栅格系统?

  栅格系统也叫做网格视图,即通过固定的格子结构,来进行设计布局网页,响应式设计就是网格视图的实现方式。

  很多网页都是基于网格设计的,这说明网页是按列来布局的。使用网格视图有助于我们设计网页,这让我们向网页添加元素变的更简单。

  响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。如下:

  响应式设计就是让一个网站兼容多个终端,即为一个页面设计多种布局结构,分别适配不同屏幕尺寸的设备,就像下图显示这样:

  通过上图,不难发现一个页面可以拆分成多个区块,而这些区块就构成了网页的布局,根据不同的屏幕尺寸,调整这些区块的排版,就可以实现响应式设计。此外,通过对比上图中不同设备的区块位置,当屏幕宽度较大时,区块倾向于水平分布,而当屏幕缩小时,区块则倾向于垂直堆叠。

  (2)、创建响应式网格视图

  首先确保所有的 HTML 元素都有 box-sizing 属性且设置为 border-box。该属性允许以确切的方式定义适应某个区域的具体内容。当值为 border-box 时,为元素设定的宽度和高度决定了元素的边框盒。也就是说,为元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制。通过从已设定的宽度和高度分别减去边框和内边距才能得到内容的宽度和高度。

  确保边距和边框包含在元素的宽度和高度间,可以添加如下代码:

 *{
box-sizing:border-box;
}

  下面的例子,是一个简单的响应式网页,包含两列:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>简单的响应式网页</title>
<style>
*{
box-sizing:border-box;
}
.header{
border:1px solid red;
padding:15px;
}
.menu{
width:25%;
float:left;
padding:15px;
border:1px solid red;
}
.main{
width:75%;
float:left;
padding:15px;
border:1px solid red;
}
</style>
</head>
<body>
<div class="header">
<h1>页头</h1>
</div>
<div class="menu">
<ul>
<li>菜单 1</li>
<li>菜单 2</li>
<li>菜单 3</li>
<li>菜单 4</li>
</ul>
</div>
<div class="main">
<h2>内容</h2>
<p>响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。</p>
<p>响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。</p>
</div>
</body>
</html>

  上例中的响应式设计只包含两列。12 列的网格系统可以更好的控制响应式网页。

  首先我们可以计算每列的百分比:100% / 12 列 = 8.33%,在每列中指定 class, class="col-" 用于定义每列有几个 span:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>简单的响应式网页</title>
<style>
*{
box-sizing:border-box;
}
.header{
border:1px solid red;
padding:15px;
}
/* 所有列左浮动 */
[class*="col-"]{
float:left;
padding:15px;
border:1px solid red;
}
/* 清除浮动 */
.row:after{
content:"";
display:block;
clear:both;
}
/* 每列的百分比: */
.col-1{width:8.33%;}
.col-2{width:16.66%;}
.col-3{width:25%;}
.col-4{width:33.33%;}
.col-5{width:41.66%;}
.col-6{width:50%;}
.col-7{width:58.33%;}
.col-8{width:66.66%;}
.col-9{width:75%;}
.col-10{width:83.33%;}
.col-11{width:91.66%;}
.col-12{width:100%;}
</style>
</head>
<body>
<div class="header">
<h1>页头</h1>
</div>
<div class="row">
<!-- <div class="menu"> -->
<div class="col-3">
<ul>
<li>菜单 1</li>
<li>菜单 2</li>
<li>菜单 3</li>
<li>菜单 4</li>
</ul>
</div>
<!-- <div class="main"> -->
<div class="col-9">
<h2>内容</h2>
<p>响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。</p>
<p>响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。</p>
</div>
</div>
</body>
</html>

  代码解析:

  每一行使用 <div> 包裹,所有列数加起来应为 12:

 <div class="row">
<div class="col-3">...</div>
<div class="col-9">...</div>
</div>

  指定所有的列向左浮动,间距(padding)为 15px:

 [class*="col-"]{
padding:15px;
border:1px solid red;
float:left;
}

  因为设置了浮动,所以需要清除浮动的影响,使用 :after 伪元素来清除浮动:

 .row:after{
content:"";
display:block;
clear:both;
}

  最后给这个简单的响应式网页添加一些样式和颜色,可在 Chrome 的开发者工具中或在 Firefox 的开发者中选择响应式设计视图,调整显示设备的尺寸来查看效果。

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>简单的响应式网页</title>
<style>
*{
box-sizing:border-box;
}
.header{
padding:15px;
background-color:#9933cc;
color:#ffffff;
}
/* 所有列左浮动 */
[class*="col-"]{
float:left;
padding:15px;
}
/* 清除浮动 */
.row:after{
content:"";
display:block;
clear:both;
}
/* 每列的百分比: */
.col-1{width:8.33%;}
.col-2{width:16.66%;}
.col-3{width:25%;}
.col-4{width:33.33%;}
.col-5{width:41.66%;}
.col-6{width:50%;}
.col-7{width:58.33%;}
.col-8{width:66.66%;}
.col-9{width:75%;}
.col-10{width:83.33%;}
.col-11{width:91.66%;}
.col-12{width:100%;} .menu ul{
list-style-type:none;
margin:0;
padding:0;
}
.menu li{
padding:8px;
margin-bottom:7px;
background-color:#33b5e5;
color:#ffffff;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.menu li:hover{
background-color:#0099cc;
}
</style>
</head>
<body>
<div class="header">
<h1>页头</h1>
</div>
<div class="row">
<!-- <div class="menu"> -->
<div class="col-3 menu">
<ul>
<li>菜单 1</li>
<li>菜单 2</li>
<li>菜单 3</li>
<li>菜单 4</li>
</ul>
</div>
<!-- <div class="main"> -->
<div class="col-9">
<h2>内容</h2>
<p>响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。</p>
<p>响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。</p>
</div>
</div>
</body>
</html>

3、响应式 Web 设计 - 媒体查询

  使用 @media 查询,你可以针对不同的媒体类型定义不同的样式。

  (1)、CSS3 @media 查询

  @media 可以针对不同的屏幕尺寸设置不同的样式,特别是如果你需要设置设计响应式的页面,@media 是非常有用的。

  当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面。

  注意:IE9+ 以及所有浏览器都支持 @media 规则。

  CSS 语法:

 @media mediatype and|not|only (media feature){
...
}

  你也可以针对不同的媒体使用不同 stylesheets:

<link rel="stylesheet" media="mediatype and|not|only (media feature)" href="style.css">

  下面的例子,如果浏览器窗口小于 600px,背景将变为浅蓝色:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>媒体查询</title>
<style>
body{
background-color:lightgreen;
}
@media only screen and (max-width:600px){
body{
background-color:lightblue;
}
}
</style>
</head>
<body>
<p>调整浏览器尺寸,当页面的宽度小于 600 像素,背景会变为浅蓝色,否则为浅绿色。</p>
</body>
</html>

  (2)、添加断点

  在之前网格视图的例子中使用行和列来制作网页,虽然他是响应式的,但通过调整浏览器的尺寸,可以发现他在小屏幕上并不能友好的展示。通过媒体查询就可以很好的解决这个问题。我们可以在样式表中添加断点,不同的断点有不同的效果。

  下面的例子,使用媒体查询在 768px 添加断点,当屏幕/浏览器窗口小于 768px,每一列的宽度是 100%:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>添加断点</title>
<style>
*{
box-sizing:border-box;
}
/* 所有列左浮动 */
[class*="col-"]{
float:left;
padding:15px;
}
/* 清除浮动 */
.row:after{
content:"";
display:block;
clear:both;
}
.header{
background-color:#9933cc;
color:#ffffff;
padding:15px;
}
.menu ul{
list-style-type:none;
margin:0;
padding:0;
}
.menu li{
padding:8px;
margin-bottom:7px;
background-color:#33b5e5;
color:#ffffff;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.menu li:hover{
background-color:#0099cc;
}
.sidebar{
background-color:#33b5e5;
padding:15px;
color:#ffffff;
text-align:center;
font-size:14px;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.footer{
background-color:#0099cc;
color:#ffffff;
text-align:center;
font-size:12px;
padding:15px;
} /* 桌面: */
.col-1{width:8.33%;}
.col-2{width:16.66%;}
.col-3{width:25%;}
.col-4{width:33.33%;}
.col-5{width:41.66%;}
.col-6{width:50%;}
.col-7{width:58.33%;}
.col-8{width:66.66%;}
.col-9{width:75%;}
.col-10{width:83.33%;}
.col-11{width:91.66%;}
.col-12{width:100%;} @media only screen and (max-width: 768px){
/* 移动设备: */
[class*="col-"]{
width: 100%;
}
}
</style>
</head>
<body>
<div class="header">
<h1>页头</h1>
</div>
<div class="row">
<div class="col-3 menu">
<ul>
<li>菜单 1</li>
<li>菜单 2</li>
<li>菜单 3</li>
<li>菜单 4</li>
</ul>
</div>
<div class="col-6">
<h2>内容</h2>
<p>响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。</p>
<p>响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。</p>
</div>
<div class="col-3 right">
<div class="sidebar">
<h2>Viewport</h2>
<p>viewport 翻译为中文为"视区/视窗/视口",就是指用户网页的可视区域。</p>
<h2>CSS 栅格系统</h2>
<p>栅格系统也叫做网格视图,即通过固定的格子结构,来进行设计布局网页,响应式设计就是网格视图的实现方式。</p>
<h2>媒体查询</h2>
<p>使用 @media 查询,你可以针对不同的媒体类型定义不同的样式。</p>
</div>
</div>
</div>
<div class="footer">
<p>页脚</p>
</div>
</body>
</html>

  (3)、为移动端优先设计

  移动端优先意味着在设计桌面和其他设备时优先考虑移动端的设计,这就意味着必须对 CSS 做一些改变。

  上面的例子在屏幕小于 768px 进行样式修改,同样移动端优先就是在屏幕宽度大于 768px 时修改样式。

  下面的代码,是移动端优先设计:

 /* 移动端优先: */
[class*="col-"]{
width:100%;
}
@media only screen and (min-width: 768px){
/* 桌面: */
.col-1{width:8.33%;}
.col-2{width:16.66%;}
.col-3{width:25%;}
.col-4{width:33.33%;}
.col-5{width:41.66%;}
.col-6{width:50%;}
.col-7{width:58.33%;}
.col-8{width:66.66%;}
.col-9{width:75%;}
.col-10{width:83.33%;}
.col-11{width:91.66%;}
.col-12{width:100%;}
}

  (4)、其他断点

  可以根据实际的需求添加断点,同样也可以为平板设备和移动设备设置断点。

  下面的代码,在屏幕为 600px 时添加媒体查询,并设置新的样式(屏幕大于 600px 但小于 768px):

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>其他断点</title>
<style>
*{
box-sizing:border-box;
}
/* 所有列左浮动 */
[class*="col-"]{
float:left;
padding:15px;
}
/* 清除浮动 */
.row:after{
content:"";
display:block;
clear:both;
}
.header{
background-color:#9933cc;
color:#ffffff;
padding:15px;
}
.menu ul{
list-style-type:none;
margin:0;
padding:0;
}
.menu li{
padding:8px;
margin-bottom:7px;
background-color:#33b5e5;
color:#ffffff;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.menu li:hover{
background-color:#0099cc;
}
.sidebar{
background-color:#33b5e5;
padding:15px;
color:#ffffff;
text-align:center;
font-size:14px;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.footer{
background-color:#0099cc;
color:#ffffff;
text-align:center;
font-size:12px;
padding:15px;
} /* 移动端优先: */
[class*="col-"]{
width: 100%;
} @media only screen and (min-width: 600px){
/* 平板 */
.col-m-1{width:8.33%;}
.col-m-2{width:16.66%;}
.col-m-3{width:25%;}
.col-m-4{width:33.33%;}
.col-m-5{width:41.66%;}
.col-m-6{width:50%;}
.col-m-7{width:58.33%;}
.col-m-8{width:66.66%;}
.col-m-9{width:75%;}
.col-m-10{width:83.33%;}
.col-m-11{width:91.66%;}
.col-m-12{width:100%;}
} @media only screen and (min-width: 768px){
/* 桌面: */
.col-1{width:8.33%;}
.col-2{width:16.66%;}
.col-3{width:25%;}
.col-4{width:33.33%;}
.col-5{width:41.66%;}
.col-6{width:50%;}
.col-7{width:58.33%;}
.col-8{width:66.66%;}
.col-9{width:75%;}
.col-10{width:83.33%;}
.col-11{width:91.66%;}
.col-12{width:100%;}
}
</style>
</head>
<body>
<div class="header">
<h1>页头</h1>
</div>
<div class="row">
<!-- <div class="col-3 menu"> -->
<div class="col-3 col-m-3 menu">
<ul>
<li>菜单 1</li>
<li>菜单 2</li>
<li>菜单 3</li>
<li>菜单 4</li>
</ul>
</div>
<!-- <div class="col-6"> -->
<div class="col-6 col-m-9">
<h2>内容</h2>
<p>响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。</p>
<p>响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。</p>
</div>
<!-- <div class="col-3 right"> -->
<div class="col-3 col-m-12 right">
<div class="sidebar">
<h2>Viewport</h2>
<p>viewport 翻译为中文为"视区/视窗/视口",就是指用户网页的可视区域。</p>
<h2>CSS 栅格系统</h2>
<p>栅格系统也叫做网格视图,即通过固定的格子结构,来进行设计布局网页,响应式设计就是网格视图的实现方式。</p>
<h2>媒体查询</h2>
<p>使用 @media 查询,你可以针对不同的媒体类型定义不同的样式。</p>
</div>
</div>
</div>
<div class="footer">
<p>页脚</p>
</div>
</body>
</html>

  注意:上面代码中,平板和桌面两组类样式是相同的,但名称不同 col- 和 col-m-,这看起来很多余,但是他们可以根据屏幕大小自动设置不同的样式,所以还是非常必要的。如下:

 <div class="row">
<div class="col-3 col-m-3">...</div>
<div class="col-6 col-m-9">...</div>
<div class="col-3 col-m-12">...</div>
</div>

  针对桌面设备:第一和第三部分跨 3 列,中间部分跨 6 列。

  针对平板设备:第一部分跨 3列,第二部分跨 9 列,第三部分跨 12 列。

  (5)、方向:横屏/竖屏

  结合 CSS 媒体查询,可以创建适应不同设备的方向(横屏 landscape、竖屏 portrait 等)的布局。

  语法:

orientation:portrait | landscape

  portrait:指定输出设备中的页面可见区域高度大于或等于宽度。

  landscape:除 portrait 值情况外,都是 landscape。

  下面的例子,如果是横屏则背景显示为浅蓝色:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>横屏/竖屏</title>
<style>
body{
background-color:lightgreen;
} @media only screen and (orientation:landscape){
body{
background-color:lightblue;
}
}
</style>
</head>
<body>
<p>调整浏览器尺寸,当页面的宽度大于高度时,背景会变为浅蓝色,否则为浅绿色。</p>
</body>
</html>

4、响应式 Web 设计 - 图片

  (1)、使用 width 属性

  如果 width 属性设置为 100%,图片会根据上下范围实现响应式功能:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>图片</title>
<style>
img{
width:100%;
height:auto;
}
</style>
</head>
<body>
<img src="data:images/xi.jpg" width="300" height="200">
<p>可以调整浏览器窗口,查看图片是如何扩展的。</p>
</body>
</html>

  注意:上面的例子,图片会比它的原始图片大,在 Chrome 中显示如下:

  扩大或缩小浏览器窗口,图片也会相应的调整自身大小,可以使用 max-width 属性很好的解决这个问题。

  (2)、使用 max-width 属性

  如果 max-width 属性设置为 100%,图片永远不会大于其原始大小:

 img{
max-width:100%;
height:auto;
}

  同样的窗口大小,在 Chrome 中显示如下:

  不管如何调整浏览器窗口大小,他始终都显示原始图片大小。

  (3)、在网页中添加图片

  将上面例子中的图片,添加到媒体查询为移动端优先设计的响应式网页中:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>响应式图片</title>
<style>
*{
box-sizing:border-box;
}
/* 所有列左浮动 */
[class*="col-"]{
float:left;
padding:15px;
}
/* 清除浮动 */
.row:after{
content:"";
display:block;
clear:both;
}
.header{
background-color:#9933cc;
color:#ffffff;
padding:15px;
}
.menu ul{
list-style-type:none;
margin:0;
padding:0;
}
.menu li{
padding:8px;
margin-bottom:7px;
background-color:#33b5e5;
color:#ffffff;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.menu li:hover{
background-color:#0099cc;
}
.sidebar{
background-color:#33b5e5;
padding:15px;
color:#ffffff;
text-align:center;
font-size:14px;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.footer{
background-color:#0099cc;
color:#ffffff;
text-align:center;
font-size:12px;
padding:15px;
} /* 移动端优先: */
[class*="col-"]{
width: 100%;
} @media only screen and (min-width: 600px){
/* 平板 */
.col-m-1{width:8.33%;}
.col-m-2{width:16.66%;}
.col-m-3{width:25%;}
.col-m-4{width:33.33%;}
.col-m-5{width:41.66%;}
.col-m-6{width:50%;}
.col-m-7{width:58.33%;}
.col-m-8{width:66.66%;}
.col-m-9{width:75%;}
.col-m-10{width:83.33%;}
.col-m-11{width:91.66%;}
.col-m-12{width:100%;}
} @media only screen and (min-width: 768px){
/* 桌面: */
.col-1{width:8.33%;}
.col-2{width:16.66%;}
.col-3{width:25%;}
.col-4{width:33.33%;}
.col-5{width:41.66%;}
.col-6{width:50%;}
.col-7{width:58.33%;}
.col-8{width:66.66%;}
.col-9{width:75%;}
.col-10{width:83.33%;}
.col-11{width:91.66%;}
.col-12{width:100%;}
} img{
width:100%;
height:auto;
}
</style>
</head>
<body>
<div class="header">
<h1>页头</h1>
</div>
<div class="row">
<!-- <div class="col-3 menu"> -->
<div class="col-3 col-m-3 menu">
<ul>
<li>菜单 1</li>
<li>菜单 2</li>
<li>菜单 3</li>
<li>菜单 4</li>
</ul>
</div>
<!-- <div class="col-6"> -->
<div class="col-6 col-m-9">
<h2>内容</h2>
<p>响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。</p>
<p>响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。</p>
<img src="data:images/xi.jpg" width="300" height="200">
</div>
<!-- <div class="col-3 right"> -->
<div class="col-3 col-m-12 right">
<div class="sidebar">
<h2>Viewport</h2>
<p>viewport 翻译为中文为"视区/视窗/视口",就是指用户网页的可视区域。</p>
<h2>CSS 栅格系统</h2>
<p>栅格系统也叫做网格视图,即通过固定的格子结构,来进行设计布局网页,响应式设计就是网格视图的实现方式。</p>
<h2>媒体查询</h2>
<p>使用 @media 查询,你可以针对不同的媒体类型定义不同的样式。</p>
</div>
</div>
</div>
<div class="footer">
<p>页脚</p>
</div>
</body>
</html>

  (4)、背景图片

  背景图片可以响应调整大小或缩放。

  以下是三个不同的方法:

  ①、如果 background-size 属性设置为 "contain",背景图片将按比例自适应内容区域,图片保持其比例不变:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>背景图片-1</title>
<style>
div{
width:100%;
height:400px;
background:url('images/xi.jpg') no-repeat;
background-size:contain;
border:2px solid red;
}
</style>
</head>
<body>
<p>调整浏览器大小查看效果。</p>
<div></div>
</body>
</html>

  在 Chrome 中显示如下:

  ②、如果 background-size 属性设置为 "100% 100%" ,背景图片将延展覆盖整个区域:

 div{
width:100%;
height:400px;
background:url('images/xi.jpg') no-repeat;
background-size:100% 100%;
border:2px solid red;
}

  在 Chrome 中显示如下:

  ③、如果 background-size 属性设置为 "cover",则会把背景图像扩展至足够大,以使背景图像完全覆盖背景区域。注意该属性保持了图片的比例,因此背景图像的某些部分无法显示在背景定位区域中:

 div{
width:100%;
height:400px;
background:url('images/xi.jpg') no-repeat;
background-size:cover;
border:2px solid red;
}

  在 Chrome 中显示如下:

  (5)、不同设备显示不同图片

  大尺寸图片可以显示在大屏幕上,但在小屏幕上确不能很好显示。因此没有必要在小屏幕上去加载大图片,这样很影响加载速度。所以可以使用媒体查询,根据不同的设备显示不同的图片。

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>不同设备显示不同图片</title>
<style>
/* 设备小于 400px:*/
body{
background:url('images/xi.jpg') no-repeat;
} /* 设备大于 400px: */
@media only screen and (min-width:400px){
body{
background-image: url('images/xi-big.jpg');
}
}
</style>
</head>
<body>
<p>调整浏览器宽度,背景图片在小于 400 px 时将改变。</p>
</body>
</html>

  当设备宽度大于 400px 时,在 Firefox 的响应式设计视图中显示如下:

  当设备宽度小于 400px 时,在 Firefox 的响应式设计视图中显示如下:

  你可以使用媒体查询的 min-device-width 替代 min-width 属性,它将检测的是设备宽度而不是浏览器宽度。注意:浏览器大小重置时,图片大小不会改变。

 /* 设备小于 400px:*/
body{
background:url('images/xi.jpg') no-repeat;
} /* 设备大于 400px: */
@media only screen and (min-device-width:400px){
body{
background-image: url('images/xi-big.jpg');
}
}

  (6)、HTML5 <picture> 元素

  HTML5 的 <picture> 元素可以设置多张图片,该元素用来处理响应式图片。

  <picture> 元素类似于 <video> 和 <audio> 元素。可以设置不同的资源,第一个设置的资源为首选使用的。

  下面的例子,使用 <picture> 元素为不同的设备显示不同的图片:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>picture 元素</title>
</head>
<body>
<picture>
<source srcset="images/xi.jpg" media="(max-width:400px)">
<source srcset="images/xi-big.jpg">
<img src="data:images/mo.jpg" alt="大漠" style="width:auto;">
</picture>
<p>调整浏览器宽度,背景图片在小于 400 px 时将改变。</p>
</body>
</html>

  source 属性的必须的,用于定义图片资源。media 属性是可选的,对于不支持 <picture> 元素的浏览器可以使用 <img> 元素来替代。

  注意:Chrome 和 Firefox 都支持该元素,IE 浏览器不支持。

  虽然 IE 不支持  <picture> 元素,但是可以通过 Picturefill.js 插件来解决 IE 浏览器的兼容性问题。

  Picturefill 是一个用于处理图片响应式的类库,他能够让你针对不同浏览器屏幕,加载对应的图片元素。我们可以利用插件让 IE 浏览器识别 <picture> 元素。在百度搜索 picturefill.js,将文件下载下来,然后在文档中引用:

 <head>
<script src="js/picturefill.js"></script>
<script>
// 通过 HTML5 shiv 方式让 IE 识别 <picture> 元素:
document.createElement( "picture" );
</script>
</head>

  在实际使用时,可以给引用文件的 script 元素添加一个 async 属性:

<script src="js/picturefill.js" async>

  这就告诉浏览器,可以异步执行脚步,仅适用于外部脚步。

  当浏览器宽度大于 400px 时,在 IE 中显示如下:

  当浏览器宽度小于 400px 时,在 IE 中显示如下:

  但是该方法只适用于 IE10+ 浏览器,IE9 仍然不支持,在 IE9 中显示如下:

5、响应式 Web 设计 - 视频

  (1)、使用 width 属性

  如果 width 属性设置为 100%,视频播放器会根据屏幕大小自动调整比例:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>视频</title>
<style>
video{
width:100%;
height:auto;
}
</style>
</head>
<body>
<video width="400" controls>
<source src="video/如果你也听说.mp4" type="video/mp4">
<source src="video/如果你也听说.webm" type="video/webm">
</video> <p>调整浏览器窗口大小,查看视频播放器变化。</p>
</body>
</html>

  注意:上面的例子,视频播放器根据屏幕大小自动调整比例,且可以比原始尺寸大。更多情况下我们可以使用 max-width 属性来替代。在 Chrome 中显示如下:

  (2)、使用 max-width 属性

  如果 max-width 属性设置为 100%,视频播放器会根据屏幕自动调整比例,但不会超过其原始大小:

 video{
max-width:100%;
height:auto;
}

  同样的窗口大小,在 Chrome 中显示如下:

  (3)、在网页中添加视频

  将上面例子中的视频,添加到之前创建的媒体查询为移动端优先设计的响应式网页中。

  该视频会根据 div 区域大小自动调整并占满整个 div 区域:

 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0"/>
<title>响应式视频</title>
<style>
*{
box-sizing:border-box;
}
/* 所有列左浮动 */
[class*="col-"]{
float:left;
padding:15px;
}
/* 清除浮动 */
.row:after{
content:"";
display:block;
clear:both;
}
.header{
background-color:#9933cc;
color:#ffffff;
padding:15px;
}
.menu ul{
list-style-type:none;
margin:0;
padding:0;
}
.menu li{
padding:8px;
margin-bottom:7px;
background-color:#33b5e5;
color:#ffffff;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.menu li:hover{
background-color:#0099cc;
}
.sidebar{
background-color:#33b5e5;
padding:15px;
color:#ffffff;
text-align:center;
font-size:14px;
box-shadow:0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.footer{
background-color:#0099cc;
color:#ffffff;
text-align:center;
font-size:12px;
padding:15px;
} /* 移动端优先: */
[class*="col-"]{
width: 100%;
} @media only screen and (min-width: 600px){
/* 平板 */
.col-m-1{width:8.33%;}
.col-m-2{width:16.66%;}
.col-m-3{width:25%;}
.col-m-4{width:33.33%;}
.col-m-5{width:41.66%;}
.col-m-6{width:50%;}
.col-m-7{width:58.33%;}
.col-m-8{width:66.66%;}
.col-m-9{width:75%;}
.col-m-10{width:83.33%;}
.col-m-11{width:91.66%;}
.col-m-12{width:100%;}
} @media only screen and (min-width: 768px){
/* 桌面: */
.col-1{width:8.33%;}
.col-2{width:16.66%;}
.col-3{width:25%;}
.col-4{width:33.33%;}
.col-5{width:41.66%;}
.col-6{width:50%;}
.col-7{width:58.33%;}
.col-8{width:66.66%;}
.col-9{width:75%;}
.col-10{width:83.33%;}
.col-11{width:91.66%;}
.col-12{width:100%;}
} video{
width:100%;
height:auto;
}
</style>
</head>
<body>
<div class="header">
<h1>页头</h1>
</div>
<div class="row">
<!-- <div class="col-3 menu"> -->
<div class="col-3 col-m-3 menu">
<ul>
<li>菜单 1</li>
<li>菜单 2</li>
<li>菜单 3</li>
<li>菜单 4</li>
</ul>
</div>
<!-- <div class="col-6"> -->
<div class="col-6 col-m-9">
<h2>内容</h2>
<p>响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整。这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的网站兼容手机和平板。</p>
<p>响应式网格视图通常是 12 列,宽度为 100%,在浏览器窗口大小调整时会自动伸缩。</p>
<video width="400" controls>
<source src="video/如果你也听说.mp4" type="video/mp4">
<source src="video/如果你也听说.webm" type="video/webm">
</video>
</div>
<!-- <div class="col-3 right"> -->
<div class="col-3 col-m-12 right">
<div class="sidebar">
<h2>Viewport</h2>
<p>viewport 翻译为中文为"视区/视窗/视口",就是指用户网页的可视区域。</p>
<h2>CSS 栅格系统</h2>
<p>栅格系统也叫做网格视图,即通过固定的格子结构,来进行设计布局网页,响应式设计就是网格视图的实现方式。</p>
<h2>媒体查询</h2>
<p>使用 @media 查询,你可以针对不同的媒体类型定义不同的样式。</p>
</div>
</div>
</div>
<div class="footer">
<p>页脚</p>
</div>
</body>
</html>

6、响应式 Web 设计 - 框架

  创建响应式网页可以使用框架来完成,比如:响应式 Web 设计框架 Bootstrap。

  Bootstrap 是基于 HTML、CSS、JsvaScript 的,它简洁灵活,使得 Web 开发更加快捷,是目前最受欢迎的前端框架。

  Bootstrap 中的网格和之前创建响应式网页的方式是相同的,默认分为 12 列,正确的写法如下:

 <div class="container">
<div class="row">
<div class="col-sm-4">
...
</div>
<div class="col-sm-4">
...
</div>
<div class="col-sm-4">
...
</div>
</div>
</div>

  使用 Bootstrap 创建响应式网页,必须理解容器(container)、行(row)和列(column)之间的层级关系。container 是网格的容器,row(.row)必须位于 container 的内部,column(如 .col-sm-4)必须位于 row 的内部,container、row、column 必须保持特定的层级结构,网格系统才能正常运行。

  

CSS 响应式设计的更多相关文章

  1. css响应式设计

    响应式设计是指在不同分辨率的设备中,网页布局可以自适应的调整.这种弹性化的布局使网站在不同设备中的布局都比较合理,可以为不同终端的用户提供更加舒适的界面和更好的用户体验,其根本理念是使原本 PC 上的 ...

  2. 响应式设计的5个CSS实用技巧

    正如我在教程响应式Web设计三步走当中所讲的,响应式的Web设计其实并不难,但是要让元素在布局切换时能够平滑过渡就比较考验技巧了.现在我分享在编码时常用的五个CSS技巧并举例说明.这些技巧都是使用简单 ...

  3. CSS响应式web设计

    参考 1. 响应式web设计之CSS3 Media Queries http://www.cnblogs.com/mofish/archive/2012/05/23/2515218.html 2. 用 ...

  4. 响应式设计:理解设备像素,CSS像素和屏幕分辨率

    概述 屏幕分辨率.设备像素和CSS像素这些术语,在非常多语境下,是可互换的,但也因此easy在有差异的地方引起混淆,实际上它们是不同的概念. 屏幕分辨率和设备像素是物理概念,而CSS像素是WEB编程的 ...

  5. 第二次讨论——响应式设计、布局技巧、css性能优化、css预处理

    第二次讨论 [响应式设计] 集中创建页面的图片排版大小,可以智能地根据用户行为以及使用的设备环境(系统平台.屏幕尺寸.屏幕定向等)进行相对应的布局. 响应式布局: meta标签的实用:设置布局宽度等于 ...

  6. css新单位vw,vh在响应式设计中的应用

    考虑到未来响应式设计的开发,如果你需要,浏览器的高度也可以基于百分比值调整.但使用基于百分比值并不总是相对于浏览器窗口的大小定义的最佳方式,比如字体大小不会随着你窗口改变而改变,如今css3引入的新单 ...

  7. Windows10 UWP开发 - 响应式设计

      Windows10 UWP开发 - 响应式设计 本篇随笔与大家简单讨论一下在开发适配不同分辨率.宽高比的Windows10 Universal App布局时的可行方式与小技巧.经验均从实践中总结, ...

  8. HTML5实践 -- 使用CSS3 Media Queries实现响应式设计

    CSS3 Media用法介绍:http://www.w3cplus.com/content/css3-media-queries 转载请注明原创地址:http://www.cnblogs.com/so ...

  9. Bootstrap 响应式设计

    本教程讲解如何在网页布局中应用响应式设计.在课程中,您将学到响应式 Web 设计.随着移动设备的普及,如何让用户通过移动设备浏览您的网站获得良好的视觉效果,已经是一个不可避免的问题了.响应式 Web ...

随机推荐

  1. windows蓝屏代码大全及常见蓝屏解决方案

    对于以下的代码查询建议使用ctrl+F查询,而且很多蓝屏与黑屏的问题多是最近操作引起的,例如更新驱动,安装新的硬件.软件--把相关的配置调到最近的正常状况大多可以解决,确实不行时方可考虑重装系统,解决 ...

  2. Codeforces Round #382 (Div. 2)E. Ostap and Tree

    E. Ostap and Tree time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  3. MSSQLSERVER数据库- 字符串分割函数返回类型表

    遇到这样一个问题,存储在数据库的数据是一串字符串如:1,2,3,4,5,6.想把这串字符串进行转变成一个表格,如下: 1 2 3 4 5 6 就是这样一个问题,有人同事,写了一个这样的封装函数,这样就 ...

  4. CAS认证(3):验证用户信息

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...

  5. C++ ComboBox基础

    关键点 实现过程 //添加 //添加字符串 m_cbo1.AddString("AAA"); m_cbo1.AddString("BBB"); m_cbo1.A ...

  6. android88 录音机

    package com.itheima.recorder; import android.os.Bundle; import android.app.Activity; import android. ...

  7. 敏捷软件工程(agile software development) VS传统软件工程(traditional software development)

    敏捷软件工程(agile software development) VS传统软件工程(traditional software development)      Agile principle  ...

  8. 聊聊动画引擎 pop

    iOS可以通过CADisplayLink实现自定义动画引擎,pop就是基于此实现的,而且比原生Core Animation更强大好用.譬如当ViewController侧滑返回的时候,系统会将Core ...

  9. 测试浏览器最多能包含Cookie的个数和Cookie中包含的最多内容

    public class CookieTestServlet extends HttpServlet { public void doGet(HttpServletRequest request, H ...

  10. axis2调用webservice

    public static long TIMEOUTINMILLISECONDS=100000; /** * 调用webservice * @param url webserviceURL * @pa ...