CSS選擇器

一.class 和 id 的使用場景?

  • class:是定位到頁面上某一類的元素重绷,它們有共同的特征谤民。
  • id:一個元素在頁面上是獨一無二的時候使用id堰酿。

二.CSS選擇器常見的有幾種?

  • 1.基礎選擇器
選擇器 含義
* 通用元素選擇器,匹配頁面任何元素(這也就決定了我們很少使用)
#id id選擇器张足,匹配特定id的元素
.class 類選擇器触创,匹配class包含(不是等于)特定類的元素
element 標簽選擇器
  • 2.組合選擇器
選擇器 含義
E,F 多元素選擇器,用,分隔为牍,同時匹配元素E或元素F
E F 后代選擇器哼绑,用空格分隔,匹配E元素所有的后代(不只是子元素碉咆、子元素向下遞歸)元素F
E>F 子元素選擇器抖韩,用>分隔,匹配E元素的所有直接子元素
E+F 直接相鄰選擇器疫铜,匹配E元素之后的相鄰的同級元素F
E~F 普通相鄰選擇器(弟弟選擇器)茂浮,匹配E元素之后的同級元素F(無論直接相鄰與否)
.class1.class2 id和class選擇器和選擇器連寫的時候中間沒有分隔符,. 和 # 本身充當分隔符的元素壳咕。匹配既包含class1和class2的元素席揽。
  • 3.屬性選擇器
選擇器 含義
E[attr] 匹配所有具有屬性attr的元素,div[id]就能取到所有有id屬性的div
E[attr = value] 匹配屬性attr值為value的元素谓厘,div[id=test],匹配id=test的div
E[attr ~= value] 匹配所有屬性attr具有多個空格分隔驹尼、其中一個值等于value的元素
E[attr ^= value] 匹配屬性attr的值以value開頭的元素
E[attr $= value] 匹配屬性attr的值以value結尾的元素
E[attr *= value] 匹配屬性attr的值包含value的元素
  • 4.偽類選擇器
選擇器 含義
E:first-child 匹配作為長子(第一個子女)的元素E
E:link 匹配所有未被點擊的鏈接
E:visited 匹配所有已被點擊的鏈接
E:active 匹配鼠標已經(jīng)其上按下、還沒有釋放的E元素
E:hover 匹配鼠標懸停其上的E元素
E:focus 匹配獲得當前焦點的E元素
E:lang(c) 匹配lang屬性等于c的E元素
E:enabled 匹配表單中可用的元素
E:disabled 匹配表單中禁用的元素
E:checked 匹配表單中被選中的radio或checkbox元素
E::selection 匹配用戶當前選中的元素
E:nth-child(n) 匹配其父元素的第n個子元素庞呕,第一個編號為1
E:first-of-type 匹配父元素下使用同種標簽的第一個子元素新翎,等同于:nth-of-type(1)
  • 5.偽元素選擇器
選擇器 含義
E::first-line 匹配E元素內(nèi)容的第一行
E::first-letter 匹配E元素內(nèi)容的第一個字母
E::before 在E元素之前插入生成的內(nèi)容
E::after 在E元素之后插入生成的內(nèi)容

三.選擇器的優(yōu)先級是怎樣的?對于復雜場景如何計算優(yōu)先級?

  • CSS選擇器的優(yōu)先級從高到低分別是:
    1.在屬性后面使用 !important 會覆蓋頁面內(nèi)任何位置定義的元素樣式
    2.作為style屬性寫在元素標簽上的內(nèi)聯(lián)樣式
    3.id選擇器
    4.類選擇器
    5.偽類選擇器
    6.屬性選擇器
    7.標簽選擇器
    8.通配符選擇器
    9.瀏覽器自定義
  • 復雜場景計算優(yōu)先級的方式:
    先假設:
    行內(nèi)樣式 <div style="xxx"></div> ==> a
    ID 選擇器 ==> b
    類住练,屬性選擇器和偽類選擇器 ==> c
    標簽選擇器地啰、偽元素 ==> d
    然后對比其大小:若a大則優(yōu)先讲逛;若a相等則對比b亏吝,b大者優(yōu)先:若b相等則對比c,c大者優(yōu)先盏混;若c相等則對比d蔚鸥,d大者優(yōu)先惜论;同級選擇器,后寫的會將之前寫的樣式覆蓋止喷。

四.a:link, a:hover, a:active, a:visited 的順序是怎樣的馆类? 為什么?

正確順序為a:link(未被觸碰) → a:visited(已被點擊) → a:hover (鼠標懸停其上)→ a:active(鼠標已經(jīng)按下弹谁,還沒有釋放)
因為a:link是未被觸碰狀態(tài)乾巧,在沒有操作是顯示a:link樣式,所以將其放在第一位;a:visited在點擊鏈接訪問過之后预愤,就會一直保持這個狀態(tài)放在第二位沟于,如果將其放在最后將會覆蓋其他樣式。

五.以下選擇器分別是什么意思?

選擇器 含義
#header{} id選擇器植康,匹配特定id=“header”的元素
.header{} 類選擇器旷太,匹配class=“header”的元素
.header .logo{} 后代選擇器,匹配class=“header”后代元素之中的class=“l(fā)ogo”的元素
.header.mobile{} 類選擇器销睁,匹配既包含class=“header”又包含class=“mobile”的元素供璧。
.header p, .header h3{} 多元素選擇器,同時匹配class=“header”元素的后代p元素或后代h3元素榄攀。
#header .nav>li{} 多元素選擇器嗜傅,匹配id="header"元素的后代class="nav"元素的直接后代li元素
#header a:hover{} 偽類選擇器金句,匹配id="header"元素的后代a元素鼠標懸浮在表面時的樣式
#header .logo~p{} 后代選擇器檩赢,匹配id=“header”的后代元素class=“l(fā)ogo”與之相連的p元素
#header input[type="text"]{} 匹配id=“header”的后代中,input元素中违寞,屬性type="text"的元素集合

六.列出你知道的偽類選擇器

選擇器 含義
E:first-child 匹配作為長子(第一個子女)的元素E
E:link 匹配所有未被點擊的鏈接
E:visited 匹配所有已被點擊的鏈接
E:active 匹配鼠標已經(jīng)其上按下贞瞒、還沒有釋放的E元素
E:hover 匹配鼠標懸停其上的E元素
E:focus 匹配獲得當前焦點的E元素
E:lang(c) 匹配lang屬性等于c的E元素
E:enabled 匹配表單中可用的元素
E:disabled 匹配表單中禁用的元素
E:checked 匹配表單中被選中的radio或checkbox元素
E::selection 匹配用戶當前選中的元素
E:nth-child(n) 匹配其父元素的第n個子元素,第一個編號為1
E:first-of-type 匹配父元素下使用同種標簽的第一個子元素趁曼,等同于:nth-of-type(1)

七.div:first-child军浆、div:first-of-type、div :first-child和div :first-of-type的作用和區(qū)別 (注意空格的作用)

  • div:first-child:匹配其父元素的第一個子元素的div元素挡闰;
  • div:first-of-type:匹配父元素下使用同種標簽的第一個子元素的div元素乒融;
  • div :first-child:匹配所有div元素內(nèi)所有元素中屬于父元素的第一個子元素;
  • div :first-of-type:匹配所有div元素內(nèi)的所有元素中屬于父元素下第一個標簽的子元素摄悯。

八.運行如下代碼赞季,解析下輸出樣式的原因。

任務7-7-1.0.png
任務7-7-2.png
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末奢驯,一起剝皮案震驚了整個濱河市申钩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌瘪阁,老刑警劉巖撒遣,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件邮偎,死亡現(xiàn)場離奇詭異,居然都是意外死亡义黎,警方通過查閱死者的電腦和手機禾进,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來轩缤,“玉大人命迈,你說我怎么就攤上這事』鸬模” “怎么了壶愤?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長馏鹤。 經(jīng)常有香客問我征椒,道長,這世上最難降的妖魔是什么湃累? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任勃救,我火速辦了婚禮,結果婚禮上治力,老公的妹妹穿的比我還像新娘蒙秒。我一直安慰自己,他們只是感情好宵统,可當我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布晕讲。 她就那樣靜靜地躺著,像睡著了一般马澈。 火紅的嫁衣襯著肌膚如雪瓢省。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天痊班,我揣著相機與錄音勤婚,去河邊找鬼。 笑死涤伐,一個胖子當著我的面吹牛馒胆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播凝果,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼祝迂,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了豆村?” 一聲冷哼從身側(cè)響起液兽,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后四啰,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宁玫,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年柑晒,在試婚紗的時候發(fā)現(xiàn)自己被綠了欧瘪。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡匙赞,死狀恐怖佛掖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情涌庭,我是刑警寧澤芥被,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站坐榆,受9級特大地震影響拴魄,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜席镀,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一匹中、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧豪诲,春花似錦顶捷、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至芳室,卻和暖如春专肪,著一層夾襖步出監(jiān)牢的瞬間刹勃,已是汗流浹背堪侯。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留荔仁,地道東北人伍宦。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像乏梁,于是被迫代替她去往敵國和親次洼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 其實平時用得多的選擇器無非也就是那么幾個遇骑,時間久了卖毁,許多不常用的選擇器就慢慢忘記了。為了不讓自己忘記這些選擇器,今...
    盛夏晚清風閱讀 1,834評論 0 5
  • 1.class 和 id 的使用場景? class:類選擇器亥啦,一個標簽可以有多個類且同一個類可以用到不同的標簽上炭剪,...
    饑人谷_兔子君閱讀 1,194評論 0 0
  • CSS選擇器結構邏輯圖 接下來按照結構邏輯圖具體講解各個選擇器的作用及用法; 基本選擇器 基本選擇器主要有以下5類...
    FoolishFlyFox閱讀 565評論 0 8
  • 一翔脱,class 和 id 的使用場景? id選擇器奴拦,匹配特定id的元素。class是類選擇器届吁,匹配class包含(...
    DeeJay_Y閱讀 363評論 0 0
  • 1错妖、class和id的使用場景分別是什么? 首先疚沐,一個HTML文件中class名字可以有多個相同的暂氯,但是id的名字...
    李博洋li閱讀 903評論 0 1