4.媒体类型与媒体查询

4.1 媒体类型

依据设备能力来分离样式的能力,始于媒体类型

媒体类型用于针对特定的环境应用样式,包括屏幕显示、打印和电视等。

通过给link元素添加media属性,可以指定在哪些设备上应用相关样式。

<link rel="stylesheet" href="main.css" media="screen, print" />

在CSS文件中指定媒体类型:

@media print {
.smallprint {
font-size: 11pt;
}
}

4.2 媒体查询

link元素中,媒体查询可以这样写:

<link rel="stylesheet" href="main.css" media="screen and (min-width: 600px)" />

这样就声明了main.css应该用于屏幕媒体,而且媒体条件是视口至少600CSS像素宽。

同样的声明可以在CSS文件中通过@media规则写成如下格式:

@media screen and (min-width: 600px) {
/* 这里写规则 */
}

width(以及min-widthmax-width)是响应式Web设计的主打属性。

宽度之所以如此重要,是因为我们创建网页的默认方式就是水平布局最多只能跟视口一样宽。而在垂直方向上,可以让内容自动扩展,用户可以垂直滚动页面。因此,知道什么时候有多少水平空间可用于布局是非常必要的。

虽然查询视口的尺寸占据了媒体查询的绝大多数,但还可以查询其他设备特性。

几乎所有浏览器都已经支持了基本的媒体查询。

条件注释是IE直至(但不含)IE10都存在的一组特殊语法。在非IE浏览器中,条件注释就像正常的HTML注释一样,会被忽略掉。

<!-- [if (lt IE 9) & (!IEMobile)]>
<link rel="stylesheet" href="oldIE.css" media="all">
<![endif]-->

5.响应式设计与结构化CSS

5.1 移动优先的CSS

移动优先,即在设计和开发中,先考虑移动设备。

min-width查询作为主要工具,可以基于视口宽度渐进地应用调整。但是也不能忽略max-width查询。

body {
font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
line-height: 1.5;
}
h1,h2,h3 {
font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
}
@media only screen and (min-width: 37.5em) {
h1,h2,h3 {
font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
}
}

这里换成max-width,代码量会减少。

body {
font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
line-height: 1.5;
}
@media only screen and (max-width: 37.5em) {
h1,h2,h3 {
font-family: 'Open Sans Condensed', 'Arial Narrow', Arial, sans-serif;
}
}

5.2 媒体查询放在何处

涉及页面布局的媒体查询放在布局相关的规则附近,涉及调整网站组件中某些细节的媒体查询放在该组件样式规则附件。

媒体查询放在哪里,并没有固定位置。作为开发者,你可以按照自己团队和项目的需要来组织CSS代码。

6.几种响应式设计模式

6.1 响应式文本列

.multicol {
column-width: 16em;
}

多栏文本在网页中应该尽量少用。

6.2 没有媒体查询的响应式Flexbox

无须使用媒体查询,Flexbox本身就可以创建出能够有效利用空间的适配布局。

相关阅读:CSS内容布局

6.3 响应式网格与网格模板区

相关阅读:CSS页面布局与网格(下)

7.响应式布局之外

7.1 响应式背景图片

<header class="profile-box" role="banner"></header>
.profile-box {
height: 300px;
background-size: cover; /* 在视口变大时,背景图片会自动变大 */
background-image: url(img/small-cat.jpg);
}
@media only screen and (min-width: 600px) {
.profile-box {
height: 600px;
background-image: url(img/big-cat.jpg);
}
}

7.2 响应式嵌入媒体

响应式媒体基础:

img, object, video, embed {
width: auto;
max-width: 100%; /* 让元素变得可以伸缩,同时又不会超过其固有大小。 */
height: auto;
}

7.3 响应式排版

屏幕大小不同,排版的基准尺寸也要相应调整。

一般来说,要将屏幕文字大小设置为20像素,才能让人感觉跟看书一样。

常见的情况是网页中的文字偏小。这通常代表了设计师或开发人员个人的喜好,而不是文本实际应有的可读性。

emrem及视口单位(vw、vh、vmin和vmax)等相对长度的字体大小很适合不同屏幕间的适配。

几乎每个浏览器的用户样式表都会设置一个16像素的基准字体大小。基于em单位的媒体查询,就是以这个由浏览器设置的基准大小为参照值的。

基于像素字体大小很难实现自动适配的布局,而使用相对大小就可以让布局伸缩更容易。

参考资料:

  • 《精通CSS》— [英] 安迪·巴德、[瑞典] 埃米尔·比约克隆德

响应式Web设计与CSS(下)的更多相关文章

  1. 响应式Web设计与CSS(上)

    1.一个例子 响应式Web设计最核心的一点,就是可以适配不同视口大小的流式布局. 1.1 简单上手 <div class="row"> <header class ...

  2. HTML5、CSS3与响应式Web设计入门(2)

    HTML5的宽泛含义开拓了Web开发的视野,增加了开发方案的多样性,同时也带给很多Web开发者不小的困惑,就是HTML5在涉及到Web某个应用领 域的开发时,到底代表了什么?本篇文章的目的就在于跟大伙 ...

  3. CSS3-基于浮动的布局,响应式WEB设计,定位网页上的元素,设计打印页面的css技术

    基于浮动的布局: 1.除非图片设置了宽度,否则始终应该要对浮动的图片设置一个宽度,这样可以让浏览器给其他内容腾出环绕的空间 2.当侧边栏的高度与主内容区的高度不一致的时候,可以用个margin进行调整 ...

  4. CSS响应式web设计

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

  5. 响应式WEB设计的9项基本原则

    响 应式Web设计对于解决多类型屏幕问题来说是个不错方案,但从印刷的角度来看,其却存在着很多的困难.没有固定的页面尺寸.没有毫米或英寸,没有任何物理 限制,让人感到无从下手.随着建立网站可用的各种小工 ...

  6. 最佳的 14 个免费的响应式 Web 设计测试工具

    一旦你决定要搭建一个网站就应该已经制定了设计标准.你认为下一步该做什么呢?测试!我使用“测试”这个词来检测你网站对不同屏幕和浏览器尺寸的响应情况.测试在响应式网页设计的过程中是很重要的一步.如果你明白 ...

  7. [转]响应式WEB设计学习(1)—判断屏幕尺寸及百分比的使用

    原文地址:http://www.jb51.net/web/70360.html 现在移动设备越来越普及,用户使用智能手机.pad上网页越来越普遍.但是传统的fix型的页面在移动终端上无法很好的显示.因 ...

  8. css014 响应式web设计

    css014 响应式web设计 一.    响应式web设计基础知识 1.rwd的三大理念:a.用于布局的弹性网络, b.用于图片和视频的弹性媒体,c.为不同屏幕宽度创建的不同样式的css媒体查询. ...

  9. 什么是响应式Web设计?怎样进行?

    http://beforweb.com/node/6/page/0/3 开始第一篇.老规矩,先无聊的谈论天气一类的话题.十一长假,天气也终于开始有些秋天的味道,坐在屋里甚至觉得需要热咖啡.话说两年前也 ...

随机推荐

  1. 记录groupby的一次操作

    df = pd.DataFrame({'key1':list('aabba'), 'key2': ['one','two','one','two','one'], 'data1': np.random ...

  2. C#数据结构与算法系列(二十三):归并排序算法(MergeSort)

    1.介绍 归并排序(MergeSort)是利用归并的思想实现的排序方法,该算法采用经典的分治策略(分治法将问题分(divide)成一些小的问题然后递归求解, 而治(conquer)的阶段则将分的阶段得 ...

  3. 题解 CF1372C

    题目 传送门 题意 给你一个 \(1\) 到 \(n\) 的排列. 定义特殊交换为:选择一段区间\([l,r]\) ,使得此段区间上的数交换后都不在原来的位置. 问最少多少次可以将此排列变成升序的. ...

  4. Git别名和配置文件

    目录 备注: 配置别名 配置文件 备注: 本文参考于廖雪峰老师的博客Git教程.依照其博客进行学习和记录,感谢其无私分享,也欢迎各位查看原文. 配置别名 如果,如果这么神器的Git版本控制系统,可以简 ...

  5. js原型、原型链

    之前有说过继承,在js中没有类,所以在new的后面,放的是构造函数,在构造函数中有一个属性prototype,js的继承全靠它. 在js中对象的类型有很多,常见的就是普通对象,和函数对象,在对象中都会 ...

  6. ~~网络编程(三):TCP/UDP~~

    进击のpython ***** 网络编程--TCP/UDP协议 其实你也发现了,应用层是交给应用来处理的,我们什么也做不了 相较于网络编程来说,我们更重要的是在做应用层和传输层的对接 因为你也看到了, ...

  7. 读懂操作系统之快表(TLB)原理(七)

    前言 前不久.我们详细分析了TLB基本原理,本节我们通过一个简单的示例再次叙述TLB的算法和原理,希望借此示例能加深我们对TLB(又称之为快表,深入理解计算机系统(第三版)又称之为翻译后备缓冲区)的理 ...

  8. vj map

    /* * 换行好烦人呀! */ #include <iostream> #include <map> #include <string> using namespa ...

  9. Python大礼包-安装视频+pycharm编译器|Mac版本+64位+32位版本pycharm安装包+python安装|内附网盘链接带提取码

    pycharm安装包+环境安装打包带走,附带视频教程与pdf教程. (下载链接在本文最下方) 多的不说,直接上图: Python大礼包-安装视频+pycharm编译器详细文件: 点击此处进入下载地址 ...

  10. Checkbutton基本写法

    1.Checkbutton(self 窗口对象,text 按钮显示内容,variable 绑定变量->一起变化, onvalue 用户点击时得到的值,offvalue 没有点击得到的值) sel ...