有哪些選擇器 基本選擇器
通配選擇器(*)
ID選擇器(#ID)
類選擇器(.className)
元素選擇器(tagName)
后代選擇器(a b)
子元素選擇器(a>b)
相鄰后面兄弟元素選擇器(a + b)
通用后面兄弟選擇器(a ? b)
群組選擇器(selector1,selector2,...)
這里面平時不太常用的選擇器有相鄰后面兄弟選擇器和通用后面兄弟選擇器
首先,很多資料上把它們叫做相鄰兄弟選擇器和通用兄弟選擇器,我覺得這樣會有一定的誤導(dǎo)意義,
例如:
`
`
當(dāng)使用相鄰兄弟選擇器時:
.l3 + li { background: green; }
效果為:
可以看出相鄰兄弟選擇器只會選擇它后面的一個兄弟元素。
當(dāng)使用通用兄弟選擇器:
.l3 ~ li { background: green; }
效果為:
可以看出來通用兄弟選擇器會選擇它后面所有的兄弟元素
屬性選擇器E[attr]:只使用屬性名,但沒有確定任何屬性值
E[attr="value"]:指定屬性名,并指定了該屬性的屬性值
E[attr~="value"]:指定屬性名,并且具有屬性值,此屬性值是一個詞列表,并且以空格隔開,其中詞列表中包含了一個value詞,而且等號前面的“?”不能不寫
E[attr^="value"]:指定了屬性名,并且有屬性值,屬性值是以value開頭的;
E[attr$="value"]:指定了屬性名,并且有屬性值,而且屬性值是以value結(jié)束的;
E[attr*="value"]:指定了屬性名,并且有屬性值,而且屬值中包含了value;
E[attr|="value"]:指定了屬性名,并且屬性值是value或者以“value-”開頭的值(比如說big-name);
屬性選擇器中有波浪(?)時屬性值有value時就相匹配,沒有波浪(?)時屬性值要完全是value時才匹配
偽類選擇器動態(tài)偽類
在鏈接中常看到的錨點偽類:link、visited、hover、active
UI元素狀態(tài)偽類
例如 :enabled,:disabled,:checked等,這些主要是對一些表單元素操作。
比較常見的如"type="text"有enable和disabled兩種狀態(tài),前者為可寫狀態(tài)后者為不可寫狀態(tài)。
first-child: 選擇某個元素的第一次的出現(xiàn)
last-child: 選擇某個元素的最后一次的出現(xiàn)
nth-child(): 選擇某個元素的一個或多個特定的條件的出現(xiàn)
權(quán)重如何計算根據(jù)樣式所在位置,對元素的影響也有關(guān)系:內(nèi)聯(lián)樣式(標(biāo)簽內(nèi)style形式) > style標(biāo)簽 > link標(biāo)簽
根據(jù)選擇器的類型,id選擇器 > 類、屬性選擇器和偽類選擇器 > 元素和偽元素
一般來說我們的計算方式為,從0開始,一個行內(nèi)樣式+1000,一個id+100,一個屬性選擇器/class或者偽類+10,一個元素名,或者偽元素+1
參考資料:
你應(yīng)該知道的一些事情-css權(quán)重
css選擇器-基本選擇器
css選擇器-屬性選擇器
css選擇器-偽類選擇器
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/52009.html
有哪些選擇器 基本選擇器 通配選擇器(*) ID選擇器(#ID) 類選擇器(.className) 元素選擇器(tagName) 后代選擇器(a b) 子元素選擇器(a>b) 相鄰后面兄弟元素選擇器(a + b) 通用后面兄弟選擇器(a ? b) 群組選擇器(selector1,selector2,...) 這里面平時不太常用的選擇器有相鄰后面兄弟選擇器和通用后面兄弟選擇器首先,很多資料上把它...
摘要:字囊括上百個前端面試題的項目開源了這個項目是什么項目內(nèi)容這個項目目前在上剛剛開源主要內(nèi)容如下前端面試題主要整理了高頻且有一定難度的前端面試題對這些面試題進行解讀前端原理詳解針對一些有一定難度面試題涉及的知識點進行詳解比如涉及的編譯原理響應(yīng)式 20W字囊括上百個前端面試題的項目開源了 這個項目是什么? 項目內(nèi)容 這個項目目前在GitHub上剛剛開源,主要內(nèi)容如下: 前端面試題: 主要整...
摘要:我們基本上都會從以下步驟入手,這些也是絕大多數(shù)運維工程師在定位故障時前幾分鐘的主要排查點一盡可能搞清楚問題的前因后果不要一下子就扎到服務(wù)器前面,你需要先搞明白對這臺服務(wù)器有多少已知的情況,還有故障的具體情況。 遇到服務(wù)器故障,問題出現(xiàn)的原因很少可以一下就想到。我們基本上都會從以下步驟入手,這些也是絕大多數(shù)運維工程師在定位故障時前幾分鐘的主要排查點:一、盡可能搞清楚問題的前因后果不要一下子就扎...
摘要:三個元素會從左往右占據(jù)父元素的空間這很顯然。左右側(cè)邊欄的寬度都是,中間元素的寬度將會占據(jù)元素的剩余寬度。同樣會導(dǎo)致父元素有部分剩余空間沒有分配。 自從開始開學(xué)習(xí) CSS 布局,想要比較靈活的把父元素的空間分配給各個子元一直是各個前端程序員的夢想。在 flex 之前,如果不是專門去搜索相關(guān)的解決方案,一般人幾乎想不出非常靈活的三(多)欄等高布局方案,而即使看了解決方案,很多人也會大呼奇技...
摘要:既然出現(xiàn)了,那怎么辦,目前并沒聽說出現(xiàn)什么新的技術(shù)替代它雖然它真的已經(jīng)很不適合現(xiàn)代的前端了,那么只能開發(fā)一個新的引擎提高性能,這就是火狐家的量子引擎又叫。這就是所謂的,火狐前一個引擎所做的那樣。 開始 本文翻譯自Inside a super fast CSS engine: Quantum CSS ,如果想要閱讀原文,可以點擊前往,以下內(nèi)容夾雜本人一些思考,翻譯也并不一定完全。 碎碎念...
閱讀 1538·2023-04-26 02:03
閱讀 4729·2021-11-22 13:53
閱讀 4632·2021-09-09 11:40
閱讀 3801·2021-09-09 09:34
閱讀 2136·2019-08-30 13:18
閱讀 3511·2019-08-30 11:25
閱讀 3305·2019-08-26 14:06
閱讀 2554·2019-08-26 13:52