内容介绍
本书从前端开发人员的需求出发,以“流”为线索,从结构、内容到美化装饰等方面,全面且深入地讲解前端开发人员必须了解和掌握的大量的CSS知识点。同时,作者结合多年的从业经验,通过大量的实战案例,详尽解析CSS的相关知识与常见问题。作者还为本书开发了专门的配套网站,进行实例展示、问题答疑。
作为一本CSS深度学习的书,书中介绍大量许多前端开发人员都不知道的CSS知识点。通过阅读本书,读者会对CSS世界的深度和广度有一个全新的认识。
作者介绍
张鑫旭,前端开发工程师,国内知名前端博客“鑫空间-鑫生活”博主,目前就职于阅文集团用户体验设计部(YUX),担任技术经理。2007年开始接触前端,10年来一直工作在前端开发一线,在HTML/CSS等与交互体验关系密切的领域花了大量的时间学习和研究,有比较多的心得体会。
卖点推荐
作者张鑫旭,前端开发工程师,国内知名前端博客“鑫空间-鑫生活”博主。
-茫茫星海中鲸鱼永不犯错的航行,
-那是因为有星辰的指引;
-芸芸CSS世界中想要不断突破瓶颈,
-需要有本书的指引。
CSS入门简单深入难,无数人遇到“天花板”,本书是打破能力上升瓶颈之作。
前端开发行业潜心近10年一直研究看似简单的CSS的人可谓是凤毛麟角,作者从2009年开始写原创技术文章,现在其博客已经成为国内访问量巨大的个人前端博客之一,可以说众多前端初学者是看着作者的博客成长的。
本书几乎所有内容都是经过作者自我思考和认知提炼后的产物,都是其他地方难得一见的“干货”。本书不会像传统书籍一样,一个知识点就是一节,因为CSS的各个属性的表现和行为相互间是参杂在一起的,很难一个一个分开,为了把错综复杂的CSS知识点讲好,本书以独特的“世界观”的视角去看待CSS。
为了拓展和更直观演示各个特性的效果,书中每个案例都有对应的在线demo演示页面,以二维码形式放在书中,方便读者扫码查看,快速体验。
目录
目 录
第 1章 概述1
1.1 CSS世界的“世界观”1
1.2 世界都是创造出来的3
1.3 CSS完胜SVG的武器—流4
1.3.1 何为“流”5
1.3.2 流是如何影响整个CSS世界的6
1.3.3 什么是流体布局6
1.4 CSS世界的开启从IE8开始6
1.5 table自己的世界7
1.6 CSS新世界—CSS37
第 2章 需提前了解的术语和概念8
2.1 务必了解的CSS世界的专业术语8
2.2 了解CSS世界中的“未定义行为”11
第3章 流、元素与基本尺寸13
3.1 块级元素13
3.1.1 为什么list-item元素会出现项目符号15
3.1.2 display:inline-table的盒子是怎样组成的16
3.1.3 width/height作用在哪个盒子上16
3.2 width/height作用的具体细节16
3.2.1 深藏不露的width:auto17
3.2.2 width值作用的细节24
3.2.3 CSS流体布局下的宽度分离原则27
3.2.4 改变width/height作用细节的box-sizing29
3.2.5 相对简单而单纯的height:auto33
3.2.6 关于height:100%33
3.3 CSS min-width/max-width和min-height/max-height二三事37
3.3.1 为流体而生的min-width/max-width38
3.3.2 与众不同的初始值38
3.3.3 !important39
3.3.4 任意高度元素的展开收起动画技术40
3.4 内联元素42
3.4.1 哪些元素是内联元素42
3.4.2 内联世界深入的基础—内联盒模型42
3.4.3 幽灵空白节点44
第4章 盒尺寸四大家族45
4.1 深入理解content45
4.1.1 content与替换元素45
4.1.2 content内容生成技术57
4.2 温和的padding属性73
4.2.1 padding与元素的尺寸73
4.2.2 padding的百分比值77
4.2.3 标签元素内置的padding79
4.2.4 padding与图形绘制80
4.3 激进的margin属性81
4.3.1 margin与元素尺寸以及相关布局82
4.3.2 margin的百分比值87
4.3.3 正确看待CSS世界里的margin合并87
4.3.4 深入理解CSS中的margin:auto94
4.3.5 margin无效情形解析97
4.4 border属性100
4.4.1 为什么border-width不支持百分比值100
4.4.2 了解各种border-style类型101
4.4.3 border-color和color105
4.4.4 border与透明边框技巧106
4.4.5 border与图形构建108
4.4.6 border等高布局技术109
第5章 内联元素与流111
5.1 字母x—CSS世界中隐匿的举足轻重的角色111
5.1.1 字母x与CSS世界的基线111
5.1.2 字母x与CSS中的x-height112
5.1.3 字母x与CSS中的ex113
5.2 内联元素的基石line-height114
5.2.1 内联元素的高度之本—line-height114
5.2.2 为什么line-height可以让内联元素“垂直居中”119
5.2.3 深入line-height的各类属性值121
5.2.4 内联元素line-height的“大值特性”124
5.3 line-height的好朋友vertical-align126
5.3.1 vertical-align家族基本认识127
5.3.2 vertical-align作用的前提129
5.3.3 vertical-align和line-height之间的关系131
5.3.4 深入理解vertical-align线性类属性值135
5.3.5 深入理解vertical-align文本类属性值141
5.3.6 简单了解vertical-align上标下标类属性值142
5.3.7 无处不在的vertical-align143
5.3.8 基于vertical-align属性的水平垂直居中弹框144
第6章 流的破坏与保护147
6.1 魔鬼属性float147
6.1.1 float的本质与特性147
6.1.2 float的作用机制151
6.1.3 float更深入的作用机制154
6.1.4 float与流体布局155
6.2 float的天然克星clear157
6.2.1 什么是clear属性157
6.2.2 成事不足败事有余的clear158
6.3 CSS世界的结界—BFC160
6.3.1 BFC的定义160
6.3.2 BFC与流体布局160
6.4 结界overflow164
6.4.1 overflow剪裁界线border box165
6.4.2 了解overflow-x和overflow-y166
6.4.3 overflow与滚动条166
6.4.4 依赖overflow的样式表现169
6.4.5 overflow与锚点定位170
6.5 float的兄弟177
6.5.1 absolute的包含块178
6.5.2 具有相对特性的无依赖absolute定位184
6.5.3 absolute与text-align191
6.6 absolute与overflow193
6.7 absolute与clip195
6.7.1 重新认识的clip属性196
6.7.2 深入了解clip的渲染198
6.8 absolute的流体特性199
6.8.1 当absolute遇到left/top/right/bottom属性199
6.8.2 absolute的流体特性200
6.8.3 absolute的margin:auto居中202
6.9 position:relative才是大哥202
6.9.1 relative对absolute的限制203
6.9.2 relative与定位203
6.9.3 relative的zui小化影响原则206
6.10 强悍的固定定位207
6.10.1 不一样的“包含块”207
6.10.2 的absolute模拟208
6.10.3 与背景锁定209
第7章 CSS世界的层叠规则211
7.1 z-index只是CSS层叠规则中的一叶小舟211
7.2 理解CSS世界的层叠上下文和层叠水平212
7.2.1 什么是层叠上下文212
7.2.2 什么是层叠水平212
7.3 理解元素的层叠顺序212
7.4 务必牢记的层叠准则214
7.5 深入了解层叠上下文214
7.5.1 层叠上下文的特性214
7.5.2 层叠上下文的创建214
7.5.3 层叠上下文与层叠顺序217
7.6 z-index负值深入理解219
7.7 z-index“不犯二”准则223
第8章 强大的文本处理能力225
8.1 line-height的另外一个朋友font-size225
8.1.1 font-size和vertical-align的隐秘故事225
8.1.2 理解font-size与ex、em和rem的关系227
8.1.3 理解font-size的关键字属性值229
8.1.4 font-size:0与文本的隐藏231
8.2 字体属性家族的大家长font-family232
8.2.1 了解衬线字体和无衬线字体233
8.2.2 等宽字体的实践价值234
8.2.3 中文字体和英文名称236
8.2.4 一些补充说明237
8.3 字体家族其他成员238
8.3.1 貌似粗犷、实则精细无比的font-weight238
8.3.2 具有近似姐妹花属性值的font-style241
8.3.3 不适合国情的font-variant242
8.4 font属性242
8.4.1 作为缩写的font属性242
8.4.2 使用关键字值的font属性243
8.4.3 font关键字属性值的应用价值246
8.5 真正了解@font face规则247
8.5.1 @font face的本质是变量247
8.5.2 @font face与字体图标技术255
8.6 文本的控制258
8.6.1 text-indent与内联元素缩进258
8.6.2 letter-spacing与字符间距261
8.6.3 word-spacing与单词间距263
8.6.4 了解word-break和word-wrap的区别264
8.6.5 white-space与换行和空格的控制265
8.6.6 text-align与元素对齐267
8.6.7 如何解决text-decoration下划线和文本重叠的问题271
8.6.8 一本万利的text-transform字符大小写273
8.7 了解:first-letter/:first-line伪元素274
8.7.1 深入:first-letter伪元素及其实例274
8.7.2 故事相对较少的:first-line伪元素277
第9章 元素的装饰与美化280
9.1 CSS世界的color很单调280
9.1.1 少得可怜的颜色关键字280
9.1.2 不支持的transparent关键字282
9.1.3 不支持的currentColor变量282
9.1.4 不支持的rgba颜色和hsla颜色282
9.1.5 支持却鸡肋的系统颜色283
9.2 CSS世界的background很单调285
9.2.1 隐藏元素的background-image到底加不加载285
9.2.2 与众不同的background-position百分比计算方式286
9.2.3 background-repeat与渲染性能287
9.2.4 外强中干的background-attachment:fixed288
9.2.5 background-color背景色永远是很低的289
9.2.6 利用多背景的属性hack小技巧290
9.2.7 渐变背景和rgba背景色的兼容处理290
第 10章 元素的显示与隐藏292
10.1 display与元素的显隐294
10.2 visibility与元素的显隐296
10.2.1 不仅仅是保留空间这么简单296
10.2.2 了解visibility:collapse301
第 11章 用户界面样式302
11.1 和border形似的outline属性302
11.1.1 万万不可在全局设置outline:0 none302
11.1.2 真正的不占据空间的outline及其应用304
11.2 光标属性cursor307
11.2.1 琳琅满目的cursor属性值307
11.2.2 自定义光标314
第 12章 流向的改变315
12.1 改变水平流向的direction315
12.1.1 direction简介315
12.1.2 direction的黄金搭档unicode-bidi318
12.2 改变CSS世界纵横规则的writing-mode320
12.2.1 writing-mode原本的作用321
12.2.2 writing-mode不经意改变了哪些规则324
12.2.3 writing-mode和direction的关系328
官方正版 CSS世界 CSS3进阶 HTML5 JavaScript 网页制作 下载 mobi epub pdf txt 电子书 格式
官方正版 CSS世界 CSS3进阶 HTML5 JavaScript 网页制作 下载 mobi pdf epub txt 电子书 格式 2025
官方正版 CSS世界 CSS3进阶 HTML5 JavaScript 网页制作 mobi epub pdf txt 电子书 格式下载 2025