使用 CSS 的 :before 和 :after 選擇器作一個箭頭樣式

對於 :before 和 :after 選擇器,你們並不陌生,可是不多有人會主動去用它們。先解釋下它們的定義和用法:css

:before 選擇器在被選元素的內容前面插入內容,:after 選擇器在被選元素的內容後面插入內容,都會使用 content 屬性來指定要插入的內容。html

有時候,項目中或多或少須要一些箭頭,若是用圖片來作,感受就有點 low 了,而上面這兩個選擇器是最好的選擇。效果以下:web

html 代碼以下:this

<div class="test"></div>

 

css 代碼以下:spa

.test {
    position: relative;
    width: 120px;
    height: 40px;
    border: 1px solid #d2d2d2;
    border-radius: 3px;
}
.test:after {
    position: absolute;
    right: 15px;
    top: 18px;
    width: 0;
    height: 0;
    content: "";
    border-width: 6px 6px 0 6px;
    border-style: solid;
    border-color: #fff transparent;
    -webkit-transition: all .25s;
       -moz-transition: all .25s;
        -ms-transition: all .25s;
         -o-transition: all .25s;
            transition: all .25s;
}

.test:before {
    position: absolute;
    right: 13px;
    top: 18px;
    width: 0;
    height: 0;
    content: "";
    border-width: 8px 8px 0 8px;
    border-style: solid;
    border-color: #d36969 transparent;
    -webkit-transition: transform .25s;
       -moz-transition: transform .25s;
        -ms-transition: transform .25s;
         -o-transition: transform .25s;
            transition: transform .25s;
}
.test.active:after{       
    top: 20px;
    -webkit-transform: rotate(180deg);
       -moz-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
         -o-transform: rotate(180deg);
            transform: rotate(180deg); 
}
.test.active:before{
    -webkit-transform: rotate(180deg);
       -moz-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
         -o-transform: rotate(180deg);
            transform: rotate(180deg);        
}

經過 :before 和 :after 兩個僞元素,設置 content 爲空,寬高爲零,邊框和顏色,生成兩個等邊三角形,一個是紅色的三角,其邊長稍大,一個是白色的三角。會有人問爲何白色三角是經過 :after 生成的,由於 :after 生成的白色三角才能覆蓋在 :before 生成的紅色三角,而造成一個箭頭(必定要設置好定位的 top 值,使兩個三角的底邊重合)。code

 

js 代碼以下:orm

$('.test').on('click',function(){
      $(this).toggleClass('active');
})

點擊的時候箭頭會旋轉180度,效果以下:htm

相關文章
相關標籤/搜索