CSS 選擇“子孫”與“弟弟妹妹”
喜歡作者的文章嗎?馬上按「關注」,當作者發佈新文章時,思書™就會 email 通知您。
思書是公開的寫作平台,創新的多筆名寫作方式,能用不同的筆名探索不同的寫作內容,無限寫作創意,如果您喜歡寫作分享,一定要來試試! 《 加入思書》
思書™是自由寫作平台,本文為作者之個人意見。
文章資訊
Categories:
Tags:
Date:
Published: 2017/11/04 - Updated: 2018/11/02
Total: 658 words
給本文個喜歡
或不
關於作者
很久以前就是個「寫程式的」,其實,什麼程式都不熟⋯⋯
就,這會一點點,那會一點點⋯⋯
看看作者的其他文章
看看思書的其他文章
又到了英文課時間了,今天要講的是 CSS 的 selectors 選擇器⋯⋯
說笑了,其實,只是我自己想做個筆記,一切又是因為那個萬惡的 Turbolinks,我又碰到了奇怪的怪異 javascript 行為,一路查 Bug 到無解,因為 Bug 又不見了,只有寫寫紀錄,消消氣,剛好有人問這,就順手寫下了。
在 CSS 裡,要選擇相關連的組件,有兩組很好用的選擇器,他們都有一對選擇關係:一個是緊鄰關係,另一個不用是緊鄰關係:
子孫關係:
.a > .b
vs..a .b
.a > .b
是選擇 children,也就是小孩,所謂的小孩,就是直接的關係,不是孫子,更不是曾曾曾孫,這是緊鄰關係。.a .b
是選擇 decendant,也就是子孫,也就是後代、後裔啦,所以,小孩也算,孫子也算,曾曾曾孫也算,這就是不緊鄰關係。例如:
.a > .b
會選到02 .b
.a .c
會選到03 .c
.a > .c
會選不到,因爲 .c 不是 .a 小孩,是孫子,不是緊鄰關係。這個選擇器討厭的地方是,“ > ” 是選小孩,這跟我們數學上常用的習慣不同,我們直覺上會覺得 “ > ” 應該是子孫,這就是討厭的地方。
弟妹關係:
同樣關於兄弟姊妹 (sibling)關係,也有一對選擇關係:也是一個緊鄰關係,另一個不用是緊鄰關係,兄弟姊妹 (sibling)關係又有限制,只能找弟弟妹妹,不能找哥哥姊姊:
.a + .b
vs.a ~ .b
.a + .b
是選擇 next sibling,就是「結著出生的弟弟妹妹」,是直接的關係,要結著生的才算,不只是弟弟妹妹就行,這是緊鄰關係。.a ~ .b
是選擇 general next sibling,也就是「弟弟妹妹都可以」,可以是二弟五妹,這就不是緊鄰關係。.c + .c1
會選到05 .c1
.c ~ .c2
會選到07 .c2
.c + .c2
會選不到,因爲 .c2 不是 .c 「隔壁」,不是緊鄰關係。多重選擇:
還有一個很常搞亂的就是兩個以上的選擇器中間沒有「空白」,這就不是選子孫或是選兄弟關係了,這是要選一個「同時」都有的多從選擇,舉例來說:
.red.yellow 就會選到那個同時有 .red 也有 .yellow 的 div,順序時沒有關係的。
搞昏了不要怪我,CSS 還有更多很昏的選擇器啊!