W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
一般情況下,sass
在解開一個(gè)嵌套規(guī)則時(shí)就會把父選擇器(#content
)通過一個(gè)空格連接到子選擇器的前邊(article
和aside
)形成(#content article
和#content aside
)。這種在CSS里邊被稱為后代選擇器,因?yàn)樗x擇ID為content
的元素內(nèi)所有命中選擇器article
和aside
的元素。但在有些情況下你卻不會希望sass
使用這種后代選擇器的方式生成這種連接。
最常見的一種情況是當(dāng)你為鏈接之類的元素寫:hover
這種偽類時(shí),你并不希望以后代選擇器的方式連接。比如說,下面這種情況sass
就無法正常工作:
article a {
color: blue;
:hover { color: red }
}
這意味著color: red
這條規(guī)則將會被應(yīng)用到選擇器article a :hover
,article
元素內(nèi)鏈接的所有子元素在被hover
時(shí)都會變成紅色。這是不正確的!你想把這條規(guī)則應(yīng)用到超鏈接自身,而后代選擇器的方式無法幫你實(shí)現(xiàn)。
解決之道為使用一個(gè)特殊的sass
選擇器,即父選擇器。在使用嵌套規(guī)則時(shí),父選擇器能對于嵌套規(guī)則如何解開提供更好的控制。它就是一個(gè)簡單的&
符號,且可以放在任何一個(gè)選擇器可出現(xiàn)的地方,比如h1
放在哪,它就可以放在哪。
article a {
color: blue;
&:hover { color: red }
}
當(dāng)包含父選擇器標(biāo)識符的嵌套規(guī)則被打開時(shí),它不會像后代選擇器那樣進(jìn)行拼接,而是&
被父選擇器直接替換:
article a { color: blue }
article a:hover { color: red }
在為父級選擇器添加:hover
等偽類時(shí),這種方式非常有用。同時(shí)父選擇器標(biāo)識符還有另外一種用法,你可以在父選擇器之前添加選擇器。舉例來說,當(dāng)用戶在使用IE瀏覽器時(shí),你會通過JavaScript
在標(biāo)簽上添加一個(gè)ie的類名,為這種情況編寫特殊的樣式如下:
#content aside {
color: red;
body.ie & { color: green }
}
/*編譯后*/
#content aside {color: red};
body.ie #content aside { color: green }
sass
在選擇器嵌套上是非常智能的,即使是帶有父選擇器的情況。當(dāng)sass
遇到群組選擇器(由多個(gè)逗號分隔開的選擇器形成)也能完美地處理這種嵌套。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: