偽元素和偽類詳解

一、偽類

1.1 定義

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

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

但是細分偽類的話,又分為動態偽類,UI元素狀態偽類,CSS3的:nth選擇器。

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

UI元素狀態偽類
:enabled type="text可寫狀態
:disabled type="text不可狀態
: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 選擇的元素里面沒有任何內容。

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 定義

偽元素:偽元素用于創建一些不在文檔樹中的元素,并且為他添加樣式,舉個例子:使用偽元素‘::before’可以在一個元素前邊增加一些文本,并且可以為這些文本添加一些樣式,雖然用戶可以看到這寫文本,但是這些文本是不存在于文檔樹中的。

1.2 幾種常見偽元素

1):frist-letter用于向文本中的第一個字母添加樣式
2):first-line向文本的首行添加樣式
3):before在元素之前添加內容
4):after在元素之后添加內容
5)::selection:匹配選中部分的內容??捎玫腃SS屬性為background,color。

1.3 偽元素和偽類的對比

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

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

1.4 偽元素的content屬性

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

div::after{
    content: "普通字符串";
    content: attr(父元素的html屬性名稱);
    content: url(圖片、音頻、視頻等資源的url);
    /* 使用unicode字符集,采用4位16進制編碼
     * 但不同的瀏覽器顯示存在差異,而且移動端識別度更差
     */
    content: "\21e0";
    /* content的多個值可以任意組合,各部分通過空格分隔 */
    content: "'" attr(title) "'";
    
    /* 自增計數器,用于插入數字/字母/羅馬數字編號
     * counter-reset: [<identifier> <integer>?]+,必選,用于標識自增計數器的作用范圍,<identifier>為自定義名稱,<integer>為起始編號默認為0。
     * counter-increment: [<identifier> <integer>?]+,用于標識計數器與實際關聯的范圍,<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>
水印
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,501評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,673評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,610評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,939評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,668評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,004評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,001評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,173評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,705評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,426評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,656評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,139評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,833評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,247評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,580評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,371評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,621評論 2 380

推薦閱讀更多精彩內容

  • 本文轉載自:眾成翻譯譯者:為之漫筆鏈接:http://www.zcfy.cc/article/239原文:http...
    極樂君閱讀 7,396評論 1 62
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標準。 注意:講述HT...
    kismetajun閱讀 27,584評論 1 45
  • 一:在制作一個Web應用或Web站點的過程中,你是如何考慮他的UI、安全性、高性能、SEO、可維護性以及技術因素的...
    Arno_z閱讀 1,202評論 0 1
  • 偽類: 偽類用于當已有元素處于的某個狀態時,為其添加對應的樣式,這個狀態是根據用戶行為而動態變化的.比如說,當用戶...
    葶寳寳閱讀 937評論 1 13
  • CSS參考手冊 一、初識CSS3 1.1 CSS是什么 CSS3在CSS2.1的基礎上增加了很多強大的新功能。目前...
    沒汁帥閱讀 3,625評論 1 13