偽元素和偽類詳解

一肖方、偽類

1.1 定義

css偽類:css偽類用于向某些選擇器添加特殊效果湿蛔。

偽類其實與普通的css類相類似,可以為已有的元素添加樣式瘫筐,但是他只有處于dom無法描述的狀態(tài)下才能為文檔樹中的元素添加樣式堤魁,所以將其稱為偽類喂链。(這種文檔樹無法描述的狀態(tài)是什么呢?當(dāng)一個元素在用戶的不同行為下就變化成不同的狀態(tài)這個行為的變化dom就無法描述妥泉,就要產(chǎn)生偽類衩藤,來為一些選擇器添加特殊的效果)。

但是細分偽類的話涛漂,又分為動態(tài)偽類,UI元素狀態(tài)偽類检诗,CSS3的:nth選擇器匈仗。

動態(tài)偽類
:link 未訪問的鏈接
:visited 已訪問的鏈接
:hover 鼠標移動到鏈接上
:active 選定的鏈接
:hover 用于當(dāng)用戶把鼠標移動到元素上面時的效果;
:focus 用于元素成為焦點
對于:hover在IE6下只有a元素支持逢慌,:active只有IE7-6不支持悠轩,:focus在IE6-7下不被

UI元素狀態(tài)偽類
:enabled type="text可寫狀態(tài)
:disabled type="text不可狀態(tài)
:checked type="radio"和"type="checkbox""有"checked"和"unchecked"兩種狀
IE6-8不支持":checked",":enabled",":disabled"這三種選擇器。

CSS3的:nth選擇器
:first-child 選擇某個元素的第一個子元素攻泼;
:last-child 選擇某個元素的最后一個子元素火架;
:nth-child() 選擇某個元素的一個或多個特定的子元素;
:nth-last-child() 選擇某個元素的一個或多個特定的子元素忙菠,從這個元素的最后一個子元素開始算何鸡;
:nth-of-type() 選擇指定的元素;
:nth-last-of-type() 選擇指定的元素牛欢,從元素的最后一個開始計算骡男;
:first-of-type 選擇一個上級元素下的第一個同類子元素;
:last-of-type 選擇一個上級元素的最后一個同類子元素傍睹;
:only-child 選擇的元素是它的父元素的唯一一個了元素隔盛;
:only-of-type 選擇一個元素是它的上級元素的唯一一個相同類型的子元素犹菱;
:empty 選擇的元素里面沒有任何內(nèi)容。

IE6-8和FF3-瀏覽器不支持":nth-child"選擇器吮炕。

1.2全部的css偽類
CSS偽類.png
1.3 偽類的常見用法

1腊脱、a標簽的偽類

a:link   /* 未訪問的鏈接 */
a:visited  /* 已訪問的鏈接 */
a:hover  /* 鼠標移動到鏈接上 */
a:active  /* 選定的鏈接 */

2、input獲取焦點 :focus

<input class="ccc" type="text" value="test" />

.ccc:focus{background-color:yellow;}

3龙亲、hover鼠標滑過

p:hover {color: #FF00FF}

一陕凹、偽元素

1.1 定義

偽元素:偽元素用于創(chuàng)建一些不在文檔樹中的元素,并且為他添加樣式俱笛,舉個例子:使用偽元素‘::before’可以在一個元素前邊增加一些文本捆姜,并且可以為這些文本添加一些樣式,雖然用戶可以看到這寫文本迎膜,但是這些文本是不存在于文檔樹中的泥技。

1.2 幾種常見偽元素

1):frist-letter用于向文本中的第一個字母添加樣式
2):first-line向文本的首行添加樣式
3):before在元素之前添加內(nèi)容
4):after在元素之后添加內(nèi)容
5)::selection:匹配選中部分的內(nèi)容】慕觯可用的CSS屬性為background,color珊豹。

1.3 偽元素和偽類的對比

(1)偽類和偽元素的最大區(qū)別就在于有沒有創(chuàng)建一個文檔樹以外的元素。偽元素創(chuàng)建了一個文檔樹以外的元素(虛擬容器)并為他添加樣式榕订,這個容器不包含任何DOM元素但是可以包含內(nèi)容店茶。換句話說偽類和偽元素的區(qū)別就是偽類的操作對象是文檔樹中已有的元素,而偽元素則創(chuàng)建了一個文檔樹以外的元素劫恒。

(2)偽類使用的是單冒號贩幻,但是在css3中規(guī)定偽元素使用的雙冒號,但是除了少部分的偽元素必須使用雙冒號以外两嘴,像after還有before都是支持單引號的丛楚。為了兼容性所以目前還是在使用一些常見的偽元素的時候采用單冒號較為穩(wěn)妥

1.4 偽元素的content屬性

偽元素的content屬性,不僅僅可以簡單直接的設(shè)置一個字符串作為偽元素的內(nèi)容憔辫,它還具備一定限度的編程能力趣些,如下

div::after{
    content: "普通字符串";
    content: attr(父元素的html屬性名稱);
    content: url(圖片、音頻贰您、視頻等資源的url);
    /* 使用unicode字符集坏平,采用4位16進制編碼
     * 但不同的瀏覽器顯示存在差異,而且移動端識別度更差
     */
    content: "\21e0";
    /* content的多個值可以任意組合锦亦,各部分通過空格分隔 */
    content: "'" attr(title) "'";
    
    /* 自增計數(shù)器舶替,用于插入數(shù)字/字母/羅馬數(shù)字編號
     * counter-reset: [<identifier> <integer>?]+,必選杠园,用于標識自增計數(shù)器的作用范圍坎穿,<identifier>為自定義名稱,<integer>為起始編號默認為0。
     * counter-increment: [<identifier> <integer>?]+玲昧,用于標識計數(shù)器與實際關(guān)聯(lián)的范圍栖茉,<identifier>為counter-reset中的自定義名稱,<integer>為步長默認為1孵延。
     * <list-style-type>: disc | circle | square | decimal | decimal-leading-zero | lower-roman | upper-roman | lower-greek | lower-latin | upper-latin | armenian | georgian | lower-alpha | upper-alpha
     */
    content: counter(<identifier>, <list-style-type>);
    
    /* 以父附屬元素的qutoes值作為content的值
     */
    content: open-quote | close-quote | no-open-quote | no-close-quote;
}
/* Content接受6種類型吕漂,和一種組合方式 */

1.4 常見的偽元素的用法

1、清除浮動

.clear:after{
    display:block;
    content:""; 
    height:0;
    clear: both;
    overflow:hidden; 
    visibility:hidden;
}

2尘应、切割線

<style>
        * {
          padding: 0;
          margin: 0;
        }
        .spliter::before, .spliter::after {
          content: '';
          display: inline-block;
          border-top: 1px solid black;
          width: 200px;
          margin: 5px;
        }
      </style>
      <p class="spliter">分割線</p>
切割線

3惶凝、對話框小箭頭

    <style>
    .arrow-right{
        margin: 500px auto;
        width:300px;
        height:80px;
        background-color: pink;
        padding-left: 20px;
    }

    .arrow-right:before{
        background-color: pink;
        content: "";
        display: block;
        width: 0;
        height: 0;  
        border-top: 10px solid #fff;
        border-bottom: 10px solid #fff;
        border-left: 20px solid pink;
        position: relative;
        top:14px;
        left: 300px;
    }
      </style>
      <p class="arrow-right">一起開黑吧?</p>
消息框

4犬钢、水印

    <style>
        .article{
            position: relative;
            padding-bottom: 30px;
        }

        .article:after{
            position: absolute;
            content:'范小飯';
            display:block;
            width: inherit;
            font-size:16px;
            text-align: center;
            color:rgba(247, 47, 47, 0.5);
            opacity: 0.5;
            bottom: 0;
            right: 0;
        }
      </style>
      <p class="article">Hi,一起吃飯吧苍鲜?</p>
水印
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市玷犹,隨后出現(xiàn)的幾起案子混滔,更是在濱河造成了極大的恐慌,老刑警劉巖歹颓,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件坯屿,死亡現(xiàn)場離奇詭異,居然都是意外死亡巍扛,警方通過查閱死者的電腦和手機领跛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來撤奸,“玉大人吠昭,你說我怎么就攤上這事‰使希” “怎么了矢棚?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長贷痪。 經(jīng)常有香客問我,道長蹦误,這世上最難降的妖魔是什么劫拢? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮强胰,結(jié)果婚禮上舱沧,老公的妹妹穿的比我還像新娘。我一直安慰自己偶洋,他們只是感情好熟吏,可當(dāng)我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般牵寺。 火紅的嫁衣襯著肌膚如雪悍引。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天帽氓,我揣著相機與錄音趣斤,去河邊找鬼。 笑死黎休,一個胖子當(dāng)著我的面吹牛浓领,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播势腮,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼联贩,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了捎拯?” 一聲冷哼從身側(cè)響起泪幌,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎玄渗,沒想到半個月后座菠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡藤树,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年浴滴,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片岁钓。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡升略,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出屡限,到底是詐尸還是另有隱情品嚣,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布钧大,位于F島的核電站翰撑,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏啊央。R本人自食惡果不足惜眶诈,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望瓜饥。 院中可真熱鬧逝撬,春花似錦、人聲如沸乓土。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至狡相,卻和暖如春梯轻,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谣光。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工檩淋, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人萄金。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓蟀悦,卻偏偏與公主長得像,于是被迫代替她去往敵國和親氧敢。 傳聞我的和親對象是個殘疾皇子日戈,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,834評論 2 345

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

  • 本文轉(zhuǎn)載自:眾成翻譯譯者:為之漫筆鏈接:http://www.zcfy.cc/article/239原文:http...
    極樂君閱讀 7,354評論 1 62
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標準孙乖。 注意:講述HT...
    kismetajun閱讀 27,422評論 1 45
  • 一:在制作一個Web應(yīng)用或Web站點的過程中浙炼,你是如何考慮他的UI、安全性唯袄、高性能弯屈、SEO、可維護性以及技術(shù)因素的...
    Arno_z閱讀 1,138評論 0 1
  • 偽類: 偽類用于當(dāng)已有元素處于的某個狀態(tài)時恋拷,為其添加對應(yīng)的樣式资厉,這個狀態(tài)是根據(jù)用戶行為而動態(tài)變化的.比如說,當(dāng)用戶...
    葶寳寳閱讀 910評論 1 13
  • CSS參考手冊 一蔬顾、初識CSS3 1.1 CSS是什么 CSS3在CSS2.1的基礎(chǔ)上增加了很多強大的新功能宴偿。目前...
    沒汁帥閱讀 3,556評論 1 13