CSS3中屬性選擇器是一種非常便捷的選擇器類型,它使用屬性值匹配元素。屬性選擇器可以根據不同的匹配方式來選擇特定的元素。下面列舉了一些常見的屬性選擇器:
/* [attr] 選擇擁有該屬性的元素 */ a[href] { color: blue; } /* [attr=val] 選擇擁有該屬性并且屬性值等于 val 的元素 */ input[type="text"] { background-color: lightgreen; } /* [attr~=val]選擇擁有該屬性并且屬性值中包含了單詞 val 的元素,可以用空格分隔多個單詞 */ p[class~="red"] { color: red; } /* [attr|="val"] 選擇擁有該屬性并且屬性值等于 val,或者該屬性值以 val- 開頭的元素 */ a[lang|="zh"] { color: red; }
屬性選擇器可以應用于任何屬性,但是應該注意:屬性選擇器只能匹配到元素的屬性,不能匹配到元素的樣式。
需要注意的是,如果你的選擇器中包含特殊字符例如 +, >, ~, * 等則需要進行轉義處理,否則會被解析為CSS語法中的選擇器符號,而不是屬性選擇器。例如:
/* 包含特殊字符的屬性選擇器需要進行轉義處理 */ input[class^=".my\\"class"] { color: red; }
上述代碼選擇了所有class屬性以 .my\class 開頭的input元素,\是特殊字符的轉義符號。
屬性選擇器在實際開發中有很多實用的應用場景,例如對于某類多個元素進行樣式控制,以及一些輔助JavaScript開發等等。在學習和使用屬性選擇器時,需要注意屬性選擇器選擇出的元素是否符合你的需求。