摘要:元素選擇器針對元素的選擇器,用于尋找指定的元素。通用選擇器通用選擇器可設置全部的元素,由一個表示。使用表示偽類選擇器。偽類選擇器包含兩種狀態偽類和結構偽類。層疊規定了選擇器的特殊性,將特殊性分為,,,四個登記,各等級特殊性逐漸降低即。
什么是選擇器?
CSS選擇器就是使樣式找到應用對象。
簡單選擇器(Simple selectors)在日常開發中,最常用的選擇器,也是最基本的選擇器。
元素選擇器(Type selector)針對HTML元素的選擇器,用于尋找指定的HTML元素。
a { color: blue; } p { color: black; }通用選擇器(Universal Selector)
通用選擇器可設置全部的HTML元素,由一個 * 表示。
* { margin: 0; }屬性選擇器(Attribute presence and value selectors)
類型 | 描述 |
---|---|
[title] | 選擇具有 title 屬性的所有元素。 |
[title="baidu"] | 選擇具有 title 屬性且值為"baidu"的所有元素。 |
[title~="baidu"] | 選擇 title 屬性值中出現的一個用空格分隔的"baidu"的元素。 |
[title^="baidu"] | 選擇 title 屬性值以 "baidu" 開頭的所有元素。 |
[title$="baidu"] | 選擇 title 屬性值以 "baidu" 結尾的所有元素。 |
[title*="baidu"] | 選擇 title 屬性值中包含字串"baidu"的所有元素。 |
以及
[title|="baidu"]:選擇 title 屬性值中等于 "baidu"或以 "baidu-"開頭的所有元素。
給HTML元素中指定了 class 的元素定義樣式。使用 . 表示。
.large-text { font-size: 18px; }ID選擇器(ID Selectors)
給HTML元素中指定了 id 的元素定義樣式。使用 # 表示。
#main-content { margin: 8px; }組選擇器(Groups of selectors)
將具有相同的樣式的元素,歸為組合來寫。使用 , 表示。
h1 { font-family: sans-serif } h2 { font-family: sans-serif } h3 { font-family: sans-serif }
等于
h1, h2, h3 { font-family: sans-serif }偽類選擇器(Pseudo-Classes)
偽類選擇器是需要根據文檔結構之外的其他條件對元素應用樣式。使用 : 表示偽類選擇器。
a:hover{ color: red }
偽類選擇器包含兩種:狀態偽類和結構偽類。
狀態偽類基于HTML元素當前狀態進行選擇的。在與用戶的交互過程中元素的狀態是動態變化的,因此該元素會根據其狀態呈現不同的樣式。當元素處于某狀態時會呈現該樣式,而進入另一狀態后,該樣式也會失去。
屬性 | 描述 | css版本 |
---|---|---|
:link | 匹配未被訪問的鏈接的元素。(標簽) | 1 |
:visited | 匹配已被訪問的鏈接的元素。(標簽) | 1 |
:active | 匹配被激活的元素。(如鼠標點擊的瞬間) | 1 |
:hover | 當鼠標懸浮在元素上方時,向元素添加樣式。 | 2 |
:focus | 匹配擁有鍵盤輸入焦點的元素。 | 2 |
:target | 匹配相關URL指向的E元素。 | 3 |
:checked | 匹配處于選中狀態的元素添加樣式。(用于input type為radio與checkbox時) | 3 |
:enabled | 向處于可用狀態的元素添加樣式。 | 3 |
:disabled | 向處于禁用狀態的元素樣式。 | 3 |
:indeterminate | 表示狀態不確定的表單元素。(用于input type為radio與checkbox及 | 3 |
結構性偽類是css3新增選擇器,利用dom樹進行元素過濾,通過文檔結構的互相關系來匹配元素,能夠減少class和id屬性的定義,使文檔結構更簡潔。
屬性 | 描述 | css版本 |
---|---|---|
:not(s) | 匹配不含有s選擇符的元素。 | 3 |
:first-child | 匹配父元素的第一個子元素E。 | 2 |
:last-child | 匹配父元素的最后一個子元素E。 | 3 |
:only-child | 匹配父元素僅有的一個子元素E。 | 3 |
:nth-child(n) | 匹配父元素的第n個子元素E。 | 3 |
:nth-last-child(n) | 匹配父元素的倒數第n個子元素E。 | 3 |
:first-of-type | 匹配同類型中的第一個同級兄弟元素E。 | 3 |
:last-of-type | 匹配同類型中的最后一個同級兄弟元素E。 | 3 |
:only-of-type | 匹配同類型中的唯一的一個同級兄弟元素E。 | 3 |
:nth-of-type(n) | 匹配同類型中的第n個同級兄弟元素E。 | 3 |
:nth-last-of-type(n) | 匹配同類型中的倒數第n個同級兄弟元素E。 | 3 |
:empty | 匹配沒有任何子元素(包括text節點)的元素。 | 3 |
:root | 匹配文檔根元素。 | |
在HTML中,根元素始終是。 | 3 |
其他偽類及相關信息請參考:偽元素選擇器(Pseudo-elements)
偽類
各偽類實現(待完成...)
偽元素是對元素中的特定內容進行操作,而不是描述狀態。它的操作層次比偽類更深一層,因此動態性比偽類低很多。實際上,偽元素就是選取某些元素前面或后面這種普通選擇器無法完成的工作??刂频膬热莺驮厥窍嗤模旧硎腔谠氐某橄螅⒉淮嬖谟谖臋n結構中!
使用 :: 表示偽元素選擇器。
屬性 | 描述 | css版本 |
---|---|---|
::first-letter | 向文本的第一個字母添加特殊樣式。 | 1 |
::first-line | 向文本的首行添加特殊樣式。 | 1 |
::before | 在元素之前添加內容。 | 2 |
::after | 在元素之后添加內容。 | 2 |
::before 和 ::after 被引入CSS中,最核心的目的,還是為了實現語義化。
使用::before 和 ::after 布局的閉合問題
.clear::after { content: ""; display: block; clear: both; }組合選擇器 后代選擇器(Descendant combinator)
由于HTML元素之間具有層次結構關系,因此在一些情況下,我們需要根據對應的HTML結構尋找指定的HTML元素。
p span{ color: #999; } ul li { font-size:14px; } #main-content div { color: black; }子選擇器(Child combinators)
選擇元素的直接子元素。使用 > 表示。
body > div { background: #c0c0c0; height: 100px; width: 100%; } body > div > div { background: red; }相鄰選擇器(Next-sibling combinator)
根據一個元素與另一個元素的相鄰關系對它應用樣式。使用 + 表示。
/* 相鄰元素選擇后面的元素進行樣式設置 */ ?li + li { border-left: 1px solid #000000; }一般兄弟選擇器(Subsequent-sibling combinator)
根據一個元素在另外一個元素后面且兩個元素都屬于一個父元素,對后面選擇的元素進行樣式設置。使用 ~ 表示。
/* 選擇后面的元素進行樣式設置 */ ?p ~ span { color: red; }選擇器層疊和特殊性
當你隨機打開一個頁面,查看源代碼,你會發現,同一個元素,不止有一個CSS選擇器及對應的樣式。而一個元素只能應用一個樣式,那么一堆樣式中究竟是應用哪一個呢?這就涉及到CSS的層疊規則了。
CSS層疊規定了選擇器的特殊性,將特殊性分為a,b,c,d四個登記,各等級特殊性逐漸降低(即a>b>c>d)。通過選擇器特殊性的比較,實現樣式選擇。
計算規則如下:
在 style 中寫的內聯樣式或加 !important 的樣式特殊性為 1,0,0,0 ( !important ?> 內聯樣式)
每個ID選擇器的特殊性為 0,1,0,0
每個類、偽類或者屬性選擇器的特殊性為 0,0,1,0
每個元素或偽元素選擇器貢獻特殊性為 0,0,0,1
組合選擇器和通配符的對特殊性沒有貢獻
用style屬性編寫的規則總是比其他任何規則特殊;具有ID選擇器的規則比沒有ID選擇器的規則特殊;具有類選擇器的規則比只有類型選擇器的規則特殊;如果兩個規則的特殊性相同,那么后定義的規則優先。參考
CSS Selector
Selectors Level 3 -- W3C Working Draft
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/114061.html
摘要:元素選擇器針對元素的選擇器,用于尋找指定的元素。通用選擇器通用選擇器可設置全部的元素,由一個表示。使用表示偽類選擇器。偽類選擇器包含兩種狀態偽類和結構偽類。層疊規定了選擇器的特殊性,將特殊性分為,,,四個登記,各等級特殊性逐漸降低即。 什么是選擇器? showImg(https://segmentfault.com/img/remote/1460000016763315?w=784&h...
摘要:為標記語言提供了一種樣式描述,定義了其中元素的顯示方式。選擇器指明了中的樣式的作用對象,也就是樣式作用于網頁中的哪些元素基本語法第一種選擇器叫選擇器在里面寫一個,通過這個就能找到這個。一、CSS是什么? 它是一種用來表現HTML(標準通用標記語言的一個應用)或XML(標準通用標記語言的一個子集)等文件樣式的計算機語言。CSS為HTML標記語言提供了一種樣式描述,定義了其中元素的顯示方式。...
摘要:相反,當響應指針事件時,它會調用創建它的代碼提供的回調函數,該函數將處理應用的特定部分?;卣{函數可能會返回另一個回調函數,以便在按下按鈕并且將指針移動到另一個像素時得到通知。它們為組件構造器的數組而提供。 來源:ApacheCN『JavaScript 編程精解 中文第三版』翻譯項目原文:Project: A Pixel Art Editor 譯者:飛龍 協議:CC BY-NC-SA 4...
摘要:本章中的大部分內容適用于構造函數和方法。第項其他方法優先于序列化第項謹慎地實現接口第項考慮使用自定義的序列化形式第項保護性地編寫方法第項對于實例控制,枚舉類型優先于第項考慮用序列化代理代替序列化實例附錄與第版中項目的對應關系參考文獻 effective-java-third-edition 介紹 Effective Java 第三版全文翻譯,純屬個人業余翻譯,不合理的地方,望指正,感激...
摘要:定場詩馬瘦毛長蹄子肥,兒子偷爹不算賊,瞎大爺娶個瞎大奶奶,老兩口過了多半輩,誰也沒看見誰前言本章為重讀學習數據結構與算法第三版的系列文章,主要講述隊列數據結構雙端隊列數據結構以及隊列相關應用。 定場詩 馬瘦毛長蹄子肥,兒子偷爹不算賊,瞎大爺娶個瞎大奶奶,老兩口過了多半輩,誰也沒看見誰! 前言 本章為重讀《學習JavaScript數據結構與算法-第三版》的系列文章,主要講述隊列數據結構、...
閱讀 3445·2021-10-14 09:42
閱讀 2736·2021-09-08 10:44
閱讀 1309·2021-09-02 10:18
閱讀 3612·2021-08-30 09:43
閱讀 2803·2021-07-29 13:49
閱讀 3729·2019-08-29 17:02
閱讀 1585·2019-08-29 15:09
閱讀 1041·2019-08-29 11:01