响应式Web设计HTML5和CSS3实战(第2版)

Standing on Shoulders of Giants.

Chapter1
  • 基于HTML5和CSS3的响应式Web设计,并不需要依赖服务端或后端方案
  • 响应式Web设计的初始[Responsive Web Design · An A List Apart Article](https://alistapart.com/article/responsive-web-design)
  • 先为小屏幕设计内容、样式,然后向大屏幕扩展
  • 渐进增强
  • 查询哪些平台和浏览器版本支持什么特性Can I use... Support tables for HTML5, CSS3, etc
  • CSS预处理器(Sass, LESS, Stylus, PostCSS)
  • 浏览器中用于呈现网页的区域叫视口(viewport)
  • meta标签:告诉浏览器如何渲染网页
    <meta name= 'viewport' content= 'width= device- width'>
    按照设备的宽度device-width来渲染网页内容
  • max-width: 100%; 保证所有图片最大显示为其自身的100%
    width: 100%; 图片按照该值显示,不考虑自身固有宽度,会导致它显示得和它的容器一样宽,甚至被无谓的拉伸
  • 媒体查询可以选择在某些条件下为网页应用不同的样式
@media screen and (min-width: 50em) {
    /* 样式 */
}
@media告诉浏览器这是一个媒体查询
screen告诉浏览器这规则只适用于屏幕类型
and (min-width: 50em)只适用于视口宽度在50恶魔以上的情况
  • 不同的长度单位:百分比,em,rem,px
  • 基本上所有浏览器默认的文本大小都是16像素,因此用像素值除以16就可以得到rem值
  • SVG( Scalable Vector Graphics) 可伸缩矢量图
  • CSS媒体查询的3级、4级标准
Chapter2
  • W3C的制定规范流程:
    WD(Working Draft, 工作草案) ->
    CR(Candidate Recommendation, 候选标准) ->
    PR(Proposed Recommendation, 建议推荐) ->
    W3C REC( Recommendation, 推荐标准)
  • CSS并不支持真正的条件逻辑或可编程特性。循环、函数、迭代和复杂的数学计算仍然只可能在CSS预处理器中看到
  • CSS的可编程方式CSS Custom Properties for Cascading Variables Module Level 1
  • 媒体查询在哪可以使用
    1. 在任何CSS文件的最后输入代码,例如
@media screen and (min-width: 300px) {
    body {
        background-color: yellow;
    }    
}

然后在head部分引用该css文件即可,<link rel='stylesheet' href='css/index.css'>
PS:JavaScript的外部引入,在body部分最后加入即可。<script src='js/index.js'></script>
可以利用CSS的重叠性实现对样式进行叠加修改

  1. 在link标签中使用
<link rel='stylesheet' type='text/css' media='screen' href='screenstyles.css'>
或
<link rel='stylesheet' media='screen and (orientation: portrait)' herf='portrait-screen.css'>
询问是否是在有屏幕的设备上,而且设备是垂直朝向的
或
<link rel='stylesheet' media='screen and (orientation: portrait) and (min-width: 800px)' herf='800wide-portrait-screen.css'>
多个媒体查询串在一起
  1. @import导入CSS时引入媒体查询
    导入CSS时使用媒体查询,有条件的向当前样式表中加载其他样式表
    @import url('phone.css') screen and (max-width: 400px);
    代码会导入样式表phone.css,但条件为必须屏幕设备,而且视口不超过400像素
    但使用CSS中的@import会增加HTTP请求
  • 关于像素单位px的更多Just use pixels – Ben Frain
  • 假设想在800像素处设置断点,但是又想用em单位,可以用800除以16,即为50em
  • 除非真的针对特定媒体类型应用样式,否则,不用写screen and
  • 性能优化的几个方面
    1. 所有图片是否都压缩了
    2. 所有脚本都拼接和缩短了
    3. 所有资源都采用Gzip压缩
    4. 所有静态内容都缓存到了CDN
    5. 所有多余的CSS规则都被清除了
  • gzip是一种压缩和解压缩的文件格式。主流服务器都支持gzip压缩CSS,从而让服务器发送给设备的文件瘦身。gzip - Wikipedia
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容