1、介紹
css3爲了區分僞類和僞元素,僞元素採用雙冒號寫法。css
常見僞類——:hover,:link,:active,:target,:not(),:focus。html
常見僞元素——::first-letter,::first-line,::before,::after,::selection。css3
::before和::after下特有的content,用於在css渲染中向元素邏輯上的頭部或尾部添加內容。web
這些添加不會出如今DOM中,不會改變文檔內容,不可複製,僅僅是在css渲染層加入。ide
因此不要用:before或:after展現有實際意義的內容,儘可能使用它們顯示修飾性內容,例如圖標。post
舉例:網站有些聯繫電話,但願在它們前加一個icon☎,就可使用:before僞元素,以下:網站
<!DOCTYPE html> <meta charset="utf-8" /> <style type="text/css"> .phoneNumber::before { content:'\260E'; font-size: 15px; } </style> <p class="phoneNumber">12345645654</p>
Note:這些特殊字符的html,js和css的寫法是不一樣的,具體可查看html特殊字符的html,js,css寫法彙總。ui
2、content屬性
::before和::after必須配合content屬性來使用,content用來定義插入的內容,content必須有值,至少是空。默認狀況下,僞類元素的display是默認值inline,能夠經過設置display:block來改變其顯示。url
content可取如下值。spa
一、string
使用引號包一段字符串,將會向元素內容中添加字符串。如:a:after{content:""}
舉例:
<!DOCTYPE html> <meta charset="utf-8" /> <style type="text/css"> p::before{ content: "《"; color: blue; } p::after{ content: "》"; color: blue; } </style> <p>平凡的世界</p>
二、attr()
經過attr()調用當前元素的屬性,好比將圖片alt提示文字或者連接的href地址顯示出來。
<style type="text/css"> a::after{ content: "(" attr(href) ")"; } </style> <a href="http://www.cnblogs.com/starof">starof</a>
三、url()/uri()
用於引用媒體文件。
舉例:「百度」前面給出一張圖片,後面給出href屬性。
<style> a::before{ content: url("https://www.baidu.com/img/baidu_jgylogo3.gif"); } a::after{ content:"("attr(href)")"; } a{ text-decoration: none; } </style> --------------------------- <body> <a href="http://www.baidu.com">百度</a> </body>
效果:
四、counter()
調用計數器,能夠不使用列表元素實現序號功能。
配合counter-increment和counter-reset屬性使用:
h2:before { counter-increment: chapter; content: "Chapter " counter(chapter) ". " }
代碼:
<style> body{ counter-reset: section; } h1{ counter-reset: subsection; } h1:before{ counter-increment:section; content:counter(section) "、"; } h2:before{ counter-increment:subsection; content: counter(section) "." counter(subsection) "、"; } </style> ------------------------------------------------ <body> <h1>HTML tutorials</h1> <h2>HTML Tutorial</h2> <h2>XHTML Tutorial</h2> <h2>CSS Tutorial</h2> <h1>Scripting tutorials</h1> <h2>JavaScript</h2> <h2>VBScript</h2> <h1>XML tutorials</h1> <h2>XML</h2> <h2>XSL</h2> </body>
效果:
瞭解更多可參考:https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Counters
3、使用
一、清除浮動
清除浮動方法有多種,如今最經常使用的就是下面這種方法,僅須要如下樣式便可在元素尾部自動清除浮動
.cf:before, .cf:after { content: " "; display: table; } .cf:after { clear: both; } .cf { *zoom: 1; }
二、模擬float:center的效果
float沒有center這個取值,可是能夠經過僞類來模擬實現。
這個效果實現頗有意思,左右經過::before float各自留出一半圖片的位置,再把圖片絕對定位上去。
核心css以下:
#page-wrap { width: 60%; margin: 40px auto; position: relative; } #logo { position: absolute; top: 0; left: 50%; margin-left: -125px; } #l, #r { width: 49%; } #l { float: left; } #r { float: right; } #l:before, #r:before { content: ""; width: 125px; height: 250px; } #l:before { float: right; } #r:before { float: left; }
完整代碼以下:
![](http://static.javashuo.com/static/loading.gif)
出自:https://css-tricks.com/float-center/
三、作出各類圖形效果
舉例:一個六角星
<style> #star-six { width: 0; height: 0; border-left: 50px solid transparent; border-right: 50px solid transparent; border-bottom: 100px solid red; position: relative; } #star-six::after { width: 0; height: 0; border-left: 50px solid transparent; border-right: 50px solid transparent; border-top: 100px solid red; position: absolute; content: ""; top: 30px; left: -50px; } </style> <body> <div id="star-six"></div> </body>
#star-six的div是一個正三角行,#star-six::after是一個倒三角形,經過絕對定位,調整其位置便可實現六角星的效果。
點我查看更多。
四、不使用圖片建立小圖標
舉例:好比一個電話
很巧妙的應用一個div左border加圓角當機身,::before和::after配合圓角當聽筒。
<style type="text/css"> #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;} #phone:before{width:15px;height:15px;background:#EEB422;border-radius: 20%;content: "";position: absolute;left:-2px;top: 1px;} #phone:after{width:15px;height:15px;background:#EEB422;border-radius: 20%;content: "";position: absolute;left:-3px;top: 34px;} </style> <div id="wraper"> <div id="phone"></div> </div>
更多圖標:
![](http://static.javashuo.com/static/loading.gif)
這個效果來自:http://www.w3cfuns.com/blog-5444604-5402127.html
有大神用僞元素建立了84種小圖標,具體可查看http://nicolasgallagher.com/pure-css-gui-icons/
五、顯示打印網頁的URL
<style> @media print { a[href]:after { content: " (" attr(href) ") "; } } </style><body> <a href="http://www.baidu.com">百度</a> </body>
六、給blockquote添加引號
常常用到給blockquote 引用段添加巨大的引號做爲背景,能夠用 ::before 來代替 background 。好處是便可以給背景留下空間,還能夠直接使用文字而非圖片:
<meta charset="utf-8"/> <style type="text/css"> blockquote::before { content: open-quote; color: #ddd; z-index: -1; font-size:80px; } </style> <blockquote>引用一個段落,雙引號用::before僞元素實現</blockquote>
七、超連接特效
舉例:配合 CSS定位實現一個鼠標移上去,超連接出現方括號的效果
<meta charset="utf-8" /> <style type="text/css"> body{ background-color: #425a6c; } a { position: relative; display: inline-block; outline: none; color: #fff; text-decoration: none; font-size: 32px; padding: 5px 20px; } a:hover::before, a:hover::after { position: absolute; } a:hover::before { content: "\5B"; left: -10px; } a:hover::after { content: "\5D"; right: -10px; } </style> <a>鼠標移上去出現方括號</a>
更多創意連接特效可參考: Creative Link Effects 。
八、::before和::after實現多背景圖片
舉例:一個標籤應用5張背景圖
![](http://static.javashuo.com/static/loading.gif)
<meta charset="utf-8" /> <style type="text/css"> #silverback { position: relative; z-index: 1; min-width: 200px; min-height: 200px; padding: 120px 200px 50px; background: #d3ff99 url(img/vines-back.png) -10% 0 repeat-x; } #silverback:before, #silverback:after { position: absolute; z-index: -1; top: 0; left: 0; right: 0; bottom: 0; padding-top: 100px; } #silverback:before { content: url(img/gorilla-1.png); padding-left: 3%; text-align: left; background: transparent url(img/vines-mid.png) 300% 0 repeat-x; } #silverback:after { content: url(img/gorilla-2.png); padding-right: 3%; text-align: right; background: transparent url(img/vines-front.png) 70% 0 repeat-x; } </style> <div id="silverback">一個標籤應用了5張背景圖片</div>
原效果來自:Multiple Backgrounds and Borders with CSS 2.1
這個效果看的真的是腦洞大開,雖然多背景圖用css3的background-image很容易就能實現。可是這篇文章是10年寫的,已通過去5年了,想一想也正是他們這樣的嘗試和努力才加速了css3標準的制定,讓今天的開發更easy。今天的咱們又能爲5年後的開發人員作些什麼貢獻呢?