CSS選擇器是CSS世界的支柱,撐起了整個精彩紛呈的CSS世界。本書專門介紹CSS選擇器的相關(guān)知識。在本書中,作者結(jié)合多年從業(yè)經(jīng)驗,在CSS基礎(chǔ)知識之上,充分考慮前端開發(fā)人員的開發(fā)需求,以CSS選擇器的基本概念、優(yōu)先級、命名、best實踐以及各偽類選擇器的適用場景為技術(shù)主線,為CSS開發(fā)人員介紹有競爭力的知識和技能。本書在第1版的基礎(chǔ)上,對選擇器的特性、兼容性等相關(guān)內(nèi)容進行了更新,并介紹了新增的選擇器。此外,本書配有專門的網(wǎng)站,用以進行實例展示和問題答疑。
作為一本CSS進階書,本書非常適合有一定CSS基礎(chǔ)的前端開發(fā)人員學(xué)習(xí)和參考。
1.專注CSS選擇器:《CSS選擇器世界》第2版,內(nèi)容與時俱進,深入剖析CSS選擇器的基礎(chǔ)概念和實際應(yīng)用場景,幫助讀者進行深度學(xué)習(xí)和掌握。
2.作者經(jīng)驗豐富:本書作者在前端開發(fā)領(lǐng)域有多年從業(yè)經(jīng)驗,能夠為讀者提供豐富的開發(fā)技巧和實踐案例。
3.實戰(zhàn)驅(qū)動:針對不同的Web開發(fā)需求提供了實用性強的技術(shù)解決方案,更多的實踐講演和更豐富的案例,讓讀者能夠更好地應(yīng)對各種開發(fā)場景和問題。
4.全面更新:覆蓋新的CSS選擇器知識和技巧,包括新增的選擇器,如:has()偽類等。
5.配套資源完備:本書配套專門的官方網(wǎng)站、在線demo和論壇,提供實例展示和問題答疑,幫助讀者更好地理解和學(xué)習(xí)CSS選擇器。
6.適合進階學(xué)習(xí):本書適用于有一定CSS基礎(chǔ)的前端開發(fā)人員學(xué)習(xí)和參考,知識體系基于實用性進行新編排,提升學(xué)習(xí)效率。通過深入學(xué)習(xí)CSS選擇器,能夠提升專業(yè)技能,并為職業(yè)發(fā)展打下堅實基礎(chǔ)。
張鑫旭
“CSS世界三部曲”(《CSS世界》《CSS選擇器世界》《CSS新世界》)作者,前端開發(fā)工程師,國內(nèi)專業(yè)前端博客“鑫空間-鑫生活”博主,目前就職于閱文集團用戶體驗設(shè)計部(YUX),擔(dān)任前端技術(shù)專家。他從2007年開始接觸前端,十多年來一直工作在前端開發(fā)一線,在HTML/CSS等與交互體驗關(guān)系密切的領(lǐng)域花了大量的時間學(xué)習(xí)和研究,有比較多的心得體會。
第 1章 概述 1
1.1 為什么CSS選擇器很強 1
1.2 CSS選擇器世界的一些基本概念 1
1.2.1 選擇器、選擇符、偽類和偽元素 2
1.2.2 CSS選擇器的作用域 3
1.2.3 CSS選擇器的命名空間 4
1.3 無效CSS選擇器的特性與實際應(yīng)用 5
第 2章 CSS聲明的優(yōu)先級 8
2.1 繼承與級聯(lián) 9
2.1.1 優(yōu)先級的底層——繼承 9
2.1.2 優(yōu)先級的中樞——級聯(lián) 10
2.2 詳解@layer規(guī)則 11
2.2.1 @layer規(guī)則解決的問題 11
2.2.2 掌握@layer規(guī)則的語法 13
2.2.3 使整個CSS變成@layer 15
2.2.4 @layer規(guī)則的嵌套 16
2.3 叛逆的!important 19
2.3.1 !important與層級跨越 19
2.3.2 !important的逆向越級 19
2.4 CSS選擇器的優(yōu)先級 20
2.4.1 同等級CSS優(yōu)先級規(guī)則概覽 20
2.4.2 CSS選擇器優(yōu)先級的計算規(guī)則21
2.4.3 256個選擇器的越級現(xiàn)象 24
2.4.4 為什么按鈕:hover變色了 25
第3章 CSS選擇器的命名 27
3.1 CSS選擇器是否區(qū)分大小寫 27
3.2 CSS選擇器命名的合法性 28
規(guī)范與更多字符的合法性 30
3.3 CSS選擇器的命名是一個哲學(xué)問題 31
3.3.1 長命名還是短命名 32
3.3.2 單命名還是組合命名 32
3.3.3 面向?qū)傩缘拿兔嫦蛘Z義的命名 34
3.3.4 我是如何命名的 36
3.4 CSS選擇器設(shè)計的最佳實踐 39
3.4.1 不要使用ID選擇器 39
3.4.2 不要嵌套選擇器 39
3.4.3 不要歧視面向?qū)傩缘拿? 42
3.4.4 正確使用狀態(tài)類名 44
3.4.5 工具帶來的變化 48
3.4.6 最佳實踐匯總 48
第4章 入門必學(xué)的選擇器 52
4.1 標(biāo)簽選擇器 52
4.1.1 標(biāo)簽選擇器二三事 52
4.1.2 特殊的標(biāo)簽選擇器:通配選擇器55
4.2 類選擇器 55
4.2.1 類選擇器脫穎而出的原因 55
4.2.2 類選擇器的其他小知識 57
4.3 ID選擇器 58
第5章 精通CSS選擇符 60
5.1 后代選擇符——空格( ) 60
5.1.1 對CSS后代選擇符可能的錯誤認(rèn)識 61
5.1.2 對JavaScript中后代選擇符可能的錯誤認(rèn)識 63
5.1.3 :scope 偽類 64
5.2 子選擇符——箭頭(>) 66
5.2.1 子選擇符和后代選擇符的區(qū)別 66
5.2.2 適合使用子選擇符的場景 67
5.3 相鄰兄弟選擇符——加號(+) 68
5.3.1 相鄰兄弟選擇符的相關(guān)細節(jié) 69
5.3.2 實現(xiàn)類似:first-child偽類的效果 70
5.3.3 眾多高級選擇器技術(shù)的核心 72
5.4 隨后兄弟選擇符——波浪線(~) 73
5.4.1 隨后兄弟選擇符和相鄰兄弟選擇符的區(qū)別 73
5.4.2 如何實現(xiàn)前面兄弟選擇符的效果 74
5.5 快速了解列選擇符——雙管道(||) 77
第6章 被低估的屬性選擇器 80
6.1 屬性值匹配選擇器逐漸興起 80
6.2 屬性值直接匹配選擇器 81
6.2.1 詳細了解4種選擇器 81
6.2.2 AMCSS開發(fā)模式簡介 87
6.3 屬性值正則匹配選擇器 88
6.3.1 詳細了解3種選擇器 88
6.3.2 CSS屬性選擇器搜索過濾技術(shù) 91
6.4 忽略屬性值大小寫的正則匹配運算符 92
第7章 常見交互行為的實現(xiàn) 94
7.1 :hover偽類與懸停交互開發(fā) 94
7.1.1 體驗優(yōu)化與:hover延時 95
7.1.2 非子元素的:hover顯示 96
7.1.3 純:hover顯示浮層的體驗問題 98
7.2 使用:active偽類實現(xiàn)點擊反饋 99
7.2.1 :active偽類概述 99
7.2.2 按鈕的通用:active樣式技巧 100
7.2.3 :active偽類與CSS數(shù)據(jù)上報 102
7.3 聚焦行為偽類:focus與用戶體驗 103
7.3.1 :focus偽類匹配機制 103
7.3.2 :focus偽類與outline輪廓 105
7.3.3 CSS:focus偽類與鍵盤無障礙訪問 106
7.4 非常實用的整體焦點偽類:focus-within 109
7.4.1 :focus-within偽類和:focus偽類的區(qū)別 109
7.4.2 :focus-within偽類實現(xiàn)無障礙訪問的下拉列表 110
7.5 鍵盤焦點偽類:focus-visible 112
:focus-visible偽類的作用及背景變化 112
第8章 通過樹結(jié)構(gòu)偽類匹配元素 115
8.1 :root偽類 115
8.1.1 :root偽類匹配的究竟是什么 116
8.1.2 :root偽類的應(yīng)用場景 117
8.2 要多使用:empty偽類 118
8.2.1 對:empty偽類可能存在的誤解 120
8.2.2 超實用超高頻使用的:empty偽類 122
8.3 比較實用的子索引偽類 124
8.3.1 :first-child偽類和:last-child偽類 124
8.3.2 給力的:only-child偽類 126
8.3.3 :nth-child()偽類和:nth-last-child()偽類 128
8.4 匹配類型的子索引偽類 136
8.4.1 :first-of-type偽類和:last-of-type偽類 136
8.4.2 :only-of-type偽類 137
8.4.3 :nth-of-type()偽類和:nth-last-of-type()偽類 138
第9章 不容小覷的邏輯組合偽類 142
9.1 務(wù)必掌握的否定偽類:not() 142
告別重置,全部交給:not()偽類 143
9.2 不要小看任意匹配偽類:is() 147
9.2.1 :is()偽類與:matches()偽類及:any()偽類之間的關(guān)系 147
9.2.2 :is()偽類的語法和兩大作用 147
9.2.3 :is()偽類在 Vue 等框架中的妙用 150
9.3 實用的優(yōu)先級調(diào)整偽類:where() 152
9.4 姍姍來遲的關(guān)聯(lián)偽類:has() 153
第 10章 鏈接與錨點開發(fā)相關(guān)的偽類 156
10.1 鏈接歷史偽類:link和:visited 156
10.1.1 深入理解:link偽類 156
10.1.2 怪癖最多的CSS偽類:visited 158
10.2 值得關(guān)注的超鏈接偽類:any-link 161
:any-link偽類相比于:link偽類的優(yōu)點. 162
10.3 實用卻很少使用的目標(biāo)偽類:target 163
10.3.1 :target偽類與錨點 164
10.3.2 :target偽類交互布局技術(shù)簡介 166
10.4 了解目標(biāo)容器偽類:target-within 170
10.5 了解鏈接匹配偽類:local-link 171
第 11章 表單開發(fā)相關(guān)的偽類 172
11.1 輸入控件狀態(tài) 172
11.1.1 可用狀態(tài)偽類:enabled與禁用狀態(tài)偽類:disabled 172
11.1.2 讀寫特性偽類:read-only和:read-write 176
11.1.3 占位符顯示偽類:placeholder-shown 177
11.1.4 使用:autofill偽類自定義自動填充樣式 180
11.1.5 默認(rèn)選項:default偽類 181
11.2 輸入值狀態(tài) 184
11.2.1 實用的選中選項偽類:checked 184
11.2.2 有用的不確定值偽類:indeterminate 196
11.3 輸入值驗證 199
11.3.1 掌握有效性驗證偽類:valid和:invalid 199
11.3.2 熟悉范圍驗證偽類:in-range和:out-of-range 203
11.3.3 熟悉可選性偽類:required和:optional 205
11.3.4 了解用戶交互偽類:user-valid和:user-invalid 210
11.3.5 簡單了解空值偽類:blank 211
11.4 表單元素專用偽元素 211
11.4.1 使用::placeholder偽元素改變占位符的樣式 212
11.4.2 使用::file-selector-button偽元素匹配文件選擇輸入框的按鈕 213
第 12章 Web Components開發(fā)中的選擇器 215
12.1 使用:defined偽類判斷組件是否初始化 215
12.1.1 普通元素的:defined適配規(guī)則 217
12.1.2 Safari不支持內(nèi)置自定義元素的處理 219
12.2 使用:host偽類匹配Shadow樹根元素 219
12.3 使用偽類:host()匹配Shadow樹根元素 221
12.4 Shadow樹根元素上下文匹配偽類:host-context() 222
12.5 使用::part偽元素穿透Shadow DOM元素 223
::part偽元素對元素也是有效的 226
第 13章 音視頻開發(fā)中的選擇器 228
13.1 音視頻元素各種狀態(tài)的匹配 228
13.1.1 使用:playing偽類、:paused 偽類和:seeking偽類匹配播放狀態(tài) 228
13.1.2 加載狀態(tài)偽類:buffering和:stalled 230
13.1.3 聲音控制偽類:muted和:volume-locked 230
13.2 視頻字幕樣式的控制 230
13.2.1 使用::cue偽元素控制字幕的樣式 231
13.2.3 了解:current、:past 和:future這些時間維度的偽類 234
第 14章 語言和文字相關(guān)的選擇器 236
14.1 了解語言相關(guān)的偽類 236
14.1.1 方向偽類:dir() 236
14.1.2 語言偽類:lang() 237
14.2 全新的文字相關(guān)的偽元素 239
14.2.1 ::mark偽元素簡介 239
14.2.2 使用::target-text偽元素高亮錨定的文字 241
14.2.3 使用::spelling-error偽元素和
::grammar-error偽元素高亮拼寫和語法錯誤 242
第 15章 元素特殊顯示狀態(tài)匹配偽類 244
15.1 了解模態(tài)層匹配偽類:modal 244
15.2 了解全屏相關(guān)的偽類:fullscreen 245
15.3 了解畫中畫偽類:picture-in-picture 247
15.4 使用::backdrop偽元素改變底部蒙層 248