::before ::after CSS3中的偽類和偽元素
::before和::after偽元素的用法
一、介紹
css3為了區分偽類和偽元素,偽元素采用雙冒號寫法。
常見偽類——:hover,:link,:active,:target,:not(),:focus。
常見偽元素——::first-letter,::first-line,::before,::after,::selection。
::before和::after下特有的content,用於在css渲染中向元素邏輯上的頭部或尾部添加內容。
這些添加不會出現在DOM中,不會改變文檔內容,不可復制,僅僅是在css渲染層加入。
所以不要用:before或:after展示有實際意義的內容,盡量使用它們顯示修飾性內容,例如圖標。
舉例:網站有些聯系電話,希望在它們前加一個icon☎,就可以使用:before偽元素,如下:
1 <!DOCTYPE html> 2 <meta charset="utf-8" /> 3 <style type="text/css"> 4 .phoneNumber::before { 5 content:'\260E'; 6 font-size: 15px; 7 } 8 </style> 9 <p class="phoneNumber">12345645654</p>
Note:這些特殊字符的html,js和css的寫法是不同的,具體可查看html特殊字符的html,js,css寫法匯總。
二、content屬性
::before和::after必須配合content屬性來使用,content用來定義插入的內容,content必須有值,至少是空。默認情況下,偽類元素的display是默認值inline,可以通過設置display:block來改變其顯示。
content可取以下值。
1、string
使用引號包一段字符串,將會向元素內容中添加字符串。如:a:after{content:""}
舉例:
1 <!DOCTYPE html> 2 <meta charset="utf-8" /> 3 <style type="text/css"> 4 p::before{ 5 content: "《"; 6 color: blue; 7 } 8 p::after{ 9 content: "》"; 10 color: blue; 11 } 12 </style> 13 <p>平凡的世界</p>
2、attr()
通過attr()調用當前元素的屬性,比如將圖片alt提示文字或者鏈接的href地址顯示出來。
1 <style type="text/css"> 2 a::after{ 3 content: "(" attr(href) ")"; 4 } 5 </style> 6 <a href="http://www.cnblogs.com/guanghe">guanghe</a>
guanghe(http://www.cnblogs.com/guanghe)
3、url()/uri()
用於引用媒體文件。
舉例:“百度”前面給出一張圖片,后面給出href屬性。
1 <style> 2 a::before{ 3 content: url("https://www.baidu.com/img/baidu_jgylogo3.gif"); 4 } 5 a::after{ 6 content:"("attr(href)")"; 7 } 8 a{ 9 text-decoration: none; 10 } 11 </style> 12 --------------------------- 13 <body> 14 <a href="http://www.baidu.com">百度</a> 15 </body>
4、counter()
調用計數器,可以不使用列表元素實現序號功能。
配合counter-increment和counter-reset屬性使用:
h2:before { counter-increment: chapter; content: "Chapter " counter(chapter) ". " }
代碼:
1 <style> 2 body{ 3 counter-reset: section; 4 } 5 h1{ 6 counter-reset: subsection; 7 } 8 h1:before{ 9 counter-increment:section; 10 content:counter(section) "、"; 11 } 12 h2:before{ 13 counter-increment:subsection; 14 content: counter(section) "." counter(subsection) "、"; 15 } 16 </style> 17 ------------------------------------------------ 18 <body> 19 <h1>HTML tutorials</h1> 20 <h2>HTML Tutorial</h2> 21 <h2>XHTML Tutorial</h2> 22 <h2>CSS Tutorial</h2> 23 24 <h1>Scripting tutorials</h1> 25 <h2>JavaScript</h2> 26 <h2>VBScript</h2> 27 28 <h1>XML tutorials</h1> 29 <h2>XML</h2> 30 <h2>XSL</h2> 31 32 </body>
三、使用
1、清除浮動
清除浮動方法有多種,現在最常用的就是下面這種方法,僅需要以下樣式即可在元素尾部自動清除浮動
1 .cf:before, 2 .cf:after { 3 content: " "; 4 display: table; 5 } 6 .cf:after { 7 clear: both; 8 } 9 .cf { 10 *zoom: 1; 11 }
2、模擬float:center的效果
float沒有center這個取值,但是可以通過偽類來模擬實現。
這個效果實現很有意思,左右通過::before float各自留出一半圖片的位置,再把圖片絕對定位上去。
核心css如下:
1 #page-wrap { width: 60%; margin: 40px auto; position: relative; } 2 #logo { position: absolute; top: 0; left: 50%; margin-left: -125px; } 3 #l, #r { width: 49%; } 4 #l { float: left; } 5 #r { float: right; } 6 #l:before, #r:before { content: ""; width: 125px; height: 250px; } 7 #l:before { float: right; } 8 #r:before { float: left; }
3、做出各種圖形效果
舉例:一個六角星
1 <style> 2 #star-six { 3 width: 0; 4 height: 0; 5 border-left: 50px solid transparent; 6 border-right: 50px solid transparent; 7 border-bottom: 100px solid red; 8 position: relative; 9 } 10 #star-six::after { 11 width: 0; 12 height: 0; 13 border-left: 50px solid transparent; 14 border-right: 50px solid transparent; 15 border-top: 100px solid red; 16 position: absolute; 17 content: ""; 18 top: 30px; 19 left: -50px; 20 } 21 </style> 22 <body> 23 <div id="star-six"></div> 24 </body>
#star-six的div是一個正三角行,#star-six::after是一個倒三角形,通過絕對定位,調整其位置即可實現六角星的效果。
4、不使用圖片創建小圖標
舉例:比如一個電話
很巧妙的應用一個div左border加圓角當機身,::before和::after配合圓角當聽筒。
1 <style type="text/css"> 2 #phone{width:50px;height:50px;border-left:6px solid #EEB422;border-radius:20%;transform:rotate(-30deg);-webkit-transform:rotate(-30deg);margin:20px;margin-right:0px;position:relative;display: inline-block;top: -5px;} 3 #phone:before{width:15px;height:15px;background:#EEB422;border-radius: 20%;content: "";position: absolute;left:-2px;top: 1px;} 4 #phone:after{width:15px;height:15px;background:#EEB422;border-radius: 20%;content: "";position: absolute;left:-3px;top: 34px;} 5 </style> 6 <div id="wraper"> 7 <div id="phone"></div> 8 </div>
1 <style> 2 @media print { 3 a[href]:after { 4 content: " (" attr(href) ") "; 5 } 6 } 7 </style><body> 8 <a href="http://www.baidu.com">百度</a> 9 </body>
6、給blockquote添加引號
經常用到給blockquote 引用段添加巨大的引號作為背景,可以用 ::before 來代替 background 。好處是即可以給背景留下空間,還可以直接使用文字而非圖片:
1 <meta charset="utf-8"/> 2 <style type="text/css"> 3 blockquote::before { 4 content: open-quote; 5 color: #ddd; 6 z-index: -1; 7 font-size:80px; 8 } 9 </style> 10 <blockquote>引用一個段落,雙引號用::before偽元素實現</blockquote>
7、超鏈接特效
舉例:配合 CSS定位實現一個鼠標移上去,超鏈接出現方括號的效果
1 <meta charset="utf-8" /> 2 <style type="text/css"> 3 body{ 4 background-color: #425a6c; 5 } 6 a { 7 position: relative; 8 display: inline-block; 9 outline: none; 10 color: #fff; 11 text-decoration: none; 12 font-size: 32px; 13 padding: 5px 20px; 14 } 15 a:hover::before, a:hover::after { position: absolute; } 16 a:hover::before { content: "\5B"; left: -10px; } 17 a:hover::after { content: "\5D"; right: -10px; } 18 </style> 19 <a>鼠標移上去出現方括號</a>
更多創意鏈接特效可參考: Creative Link Effects 。
8、::before和::after實現多背景圖片
舉例:一個標簽應用5張背景圖