菜鳥救星網頁設計教學:一次搞懂CSS3選擇器
data:image/s3,"s3://crabby-images/76f63/76f6302edbf41bd014a2a828b107b4f20ddbc5bb" alt=""
文、菜鳥編
CSS除了id,class選擇器外,你還知道有哪些?其實在CSS3的規範之下,還有許多相當好用的選擇器可提升開發靈活性。如果你還不是很了解,就以Excel來說吧,假使要你在一堆資料中,找出儲存格中內容中有包含「網頁」的字串,而且結尾必須是「好簡單」。你能立馬知道有哪些函數可以幫助你完成嗎?我很常說,工具它只是工具,還是幫手,就單看你怎麼使用。條條道路通羅馬,在完成結果的過程中,你是要走捷徑還是繞徑,就會影響你的效率甚大。
而CSS3選擇器的組合使用,就看你對它知道多少。這麼多的方式,不可能每一樣都經常會使用到,但至少當遇到問題時要能知道方向在哪裡。好比說,你會在技術討論區看過一堆新手的發問,明明只要一個站內搜尋就可以解決,偏偏還要發問讓人損!這真的不能怪罪他們,因為他們連搜尋的關鍵字要打什麼都不知道,不是嗎?所以多接觸是好事,有方向才會知道怎麼找答案。這次就來介紹幾個在CSS中好用的選擇器。
1. 通用選擇器「*」:
星號標誌意旨所有元素,相信你在網路上經常看到下面的編碼,用來將margin與padding歸零。但如果可以,真的建議別用在生產環境的代碼中,因為可能會造成瀏覽器負擔,有時甚至可能是沒必要的編寫方式。
data:image/s3,"s3://crabby-images/ac0c0/ac0c09850d04acd64d6edabdfd794ff4e9230471" alt=""
2. 子選擇器:
既然是子選擇器,就一定會有父子關係,先來看以下下面的例子,在class=”demo”下的li都會套用到紅色字體的設定。
data:image/s3,"s3://crabby-images/89ef8/89ef892ab094cdbd6914161d8621bc5b172c1f20" alt=""
data:image/s3,"s3://crabby-images/61e4a/61e4a847a7c360a849e00ea23133b8af7ae9b39a" alt=""
當我在其中一個li中再插入一個項目清單,可以看到顏色直接套用。
data:image/s3,"s3://crabby-images/70a6d/70a6d9e1d890813b1154f2a80c1df29642c64a41" alt=""
主要是因為當我們使用空格方式時,是會影響到「後代所有的元素」,當把空格改成「>」時,就只會影響到子元素層級,後來所插入的清單並非父子關係,所以就不會被直接套用。
data:image/s3,"s3://crabby-images/f4d6e/f4d6e7e1d31e6121c1790fb0f822435114feafd0" alt=""
3. 型態選擇器:
型態選擇器又稱標籤選擇器,主要套用在HTML標籤上,如下面的例子,直接就可將樣式套用在ul與li標籤上。
data:image/s3,"s3://crabby-images/fec68/fec68bd30f2775f647a7fcc73a304a8413c4690c" alt=""
結果:
data:image/s3,"s3://crabby-images/99b5b/99b5bfc1ef2b96e81b940feea1991ca4c140af5c" alt=""
4. 屬性選擇器:
作用是針對標籤中有特定屬內容的會套用CSS設定,在HTML5中新增的data-* attribute屬性,就很適合搭配使用,總共6種方式,如果有接觸過正則表達式的人,應該就不陌生。
以剛才的範例,在li中加入了data屬性:
data:image/s3,"s3://crabby-images/e890b/e890b3cdbecf6b01fed34b89f21f2fdd6c40bf9d" alt=""
[ attribute ]:
將CSS套用在標籤中有「data-index」屬性的li 元素
data:image/s3,"s3://crabby-images/5b476/5b47608ecb5faac7a2c7eddf7f51a74c386ee3a8" alt=""
data:image/s3,"s3://crabby-images/3e32d/3e32da1798090438b193742d696580ee6d6641f0" alt=""
[ attribute = value ]
將CSS套用在屬性「data-index = ‘1’」的li 元素
data:image/s3,"s3://crabby-images/8f06d/8f06d2407a43d909d2d9ce3a4f9c7cfa0d413cb2" alt=""
data:image/s3,"s3://crabby-images/d68b8/d68b85d3ed653b6ec6c0ee000dbf6ce425ef0850" alt=""
[ attribute ~= value ]
將CSS套用在屬性data-item 中有包含”sample”的所有元素
data:image/s3,"s3://crabby-images/5af69/5af6949fe75c1c6dc39e705dcfb1a36467aa0315" alt=""
data:image/s3,"s3://crabby-images/1d3a8/1d3a83b2942710c05a3cc2a79b9fe7a756b28d75" alt=""
[ attribute ^= value ]
將CSS套用在屬性data-item 中以”d”開頭的所有元素
data:image/s3,"s3://crabby-images/53d82/53d82d03472a01feb37f6610c0427dd004b4c9f3" alt=""
data:image/s3,"s3://crabby-images/57eb6/57eb6db877b65cce730b7d640ee79b6741077f95" alt=""
[ attribute $= value ]
將CSS套用在屬性data-item 中以”g”結尾的所有元素
data:image/s3,"s3://crabby-images/0825e/0825e8bb2a21b58792695f52f39acc3857f9339e" alt=""
data:image/s3,"s3://crabby-images/60281/60281c24193165e0e376c14a1255427c4c883b19" alt=""
[ attribute *= value ]
將CSS套用在屬性data-item 中有包含”o”的所有元素,你可能會覺得與[ attribute ~= value ]有點類似,使用「~」算是完全比對,也就是屬性中的值與完全等於你指定的字串,而「*」屬模糊比對,只要有包含即可。
data:image/s3,"s3://crabby-images/7529c/7529c9d1ce141ad62e196ed2fa0010db98209571" alt=""
data:image/s3,"s3://crabby-images/72c7b/72c7bb377d4e53784fa81de5de34be406ad39046" alt=""
使用屬性選擇器,就可以一次將網頁中結尾是.jpeg的圖片做CSS設定,或是特定網頁連結的效果設定等等......。
5. 同層選擇器:
又分同層相鄰(+)與同層全體(~),以下面案例來說,在加上「+li」時,依照前面屬性選擇器來看,只要有data-index=’2’的元素會被套用,也就是cat的元素。但因使用了「同層相鄰」結果就是只有bear字體會變成紅色。
data:image/s3,"s3://crabby-images/8f2a7/8f2a782b87e8360bf572566c8789e0fe2ba8eb6b" alt=""
data:image/s3,"s3://crabby-images/b653a/b653ac7b4f1a9f8d4f082a5c1c73ef271e5608e2" alt=""
相同的,當使用了同層全體時,在cat後方相同層級的li就都會套用。
data:image/s3,"s3://crabby-images/4bd8f/4bd8f1a6a482c98f6bf640c50968e54e2b5f698d" alt=""
data:image/s3,"s3://crabby-images/391f8/391f83e9bbaa09e098c9d3eb320430faf5d1f016" alt=""
應該不難觀察到,只會套用在指定元素之後的同層元素,之前的同層元素則會保持原樣。
6. 偽類&偽元素:
很多人可能會分不清楚這兩者的差別,這邊用簡單的方式來說,偽類可把它想成是狀態的設定,例如連結樣式的設定,滑鼠滑過、連結樣式、點擊後的連結樣式等等,而偽元素可以想成始選取元素的指定部分。例如大家最熟悉的「before」與「after」。由於W3C中這類的型態相當多,列舉幾個大家最常使用的。
偽類:
data:image/s3,"s3://crabby-images/6d89d/6d89d0ec978c714b37872c23cfbe2d313ea387d9" alt=""
偽元素:
:first-line、:first-letter、:before、:after
結構中的使用大同小異,主要都是用來挑選特定的元素,以這邊的案例來說,nth-child(1),就會選定「dog」的li元素,也等於「:first-child」。
data:image/s3,"s3://crabby-images/dd75f/dd75fe97832bda98889be0573fb03d0001b49865" alt=""
相對的,「: last -child」、「nth-last-child(1)」相同,都是指向最後一個li元素。first-child與last-child不能指定,分別指向第一個與最後一個元素。而nth-child與nth-last-child必須要給予一個正整數的參數,以1為基數。下例就是指定倒數第二個元素。
data:image/s3,"s3://crabby-images/1b089/1b0897f8f6ea5944054145df9f47916bbe331016" alt=""
搞懂這些選擇器,開發上就可以將樣是快速的套用到指定的位置上,不要將樣式表一層一層指定,不僅增加檔案大小,閱讀上也相當不便,如果你覺得這篇文章很實用,也別忘了分享給你的親友們,相信對他們一定很有幫助!
加入菜鳥救星官方Line並回覆「我想看文章」,不定期獲得更多知識吧!
不同頻道,不同知識!
Facebook Instagram Youtube