各種瀏覽器之間的競(jìng)爭(zhēng)的白熱化意味著越來越多的人現(xiàn)在開始使用那些支持最新、最先進(jìn)的W3C Web標(biāo)準(zhǔn)的設(shè)備,以一種更具交互性的方式來訪問互聯(lián)網(wǎng)。這意味著我們終于能夠利用更強(qiáng)大更靈活的CSS來創(chuàng)造更簡(jiǎn)潔,更好維護(hù)的瀏覽器前端代碼?,F(xiàn)在讓我們來看一看一些也許你還不知道的讓人興奮的CSS 功能。
在CSS中用attr()顯示HTML屬性值
attr()功能早在CSS 2.1標(biāo)準(zhǔn)中就已經(jīng)出現(xiàn),但現(xiàn)在才開始普遍流行。它提供了一個(gè)巧妙的方法在CSS中使用HTML標(biāo)簽上的屬性,在很多情況下都能幫你省去了以往需要Javascript處理的過程。
要想使用這個(gè)功能,你需要用到三種元素:一個(gè):before 或 :after CSS偽類樣式, .content屬性,和一個(gè)帶有你想使用的HTML屬性名稱的attr()表達(dá)式。例如,想去顯示<h3>標(biāo)題上的data-prefix屬性的值,你可以寫成這樣:
CSS Code復(fù)制內(nèi)容到剪貼板
h3:before {
content: attr(data-prefix) " ";
}
<h3 data-prefix="Custom prefix">This is a heading</h3>
顯然,這個(gè)例子并沒有展示它有多大用處,只是展示了它的基本用法。讓我們來試一個(gè)更有用的例子,attr()的一個(gè)極好的應(yīng)用就是當(dāng)用戶打印頁(yè)面時(shí)將頁(yè)面鏈接顯示出來。為了實(shí)現(xiàn)這個(gè),你可以這樣寫:
CSS Code復(fù)制內(nèi)容到剪貼板
@media print {
a:after {
content: " (link to " attr(href) ") ";
}
}
<a href="http://example.com">Visit our home page</a>
一旦你知道了這個(gè)技巧,你就會(huì)吃驚于很多時(shí)候它能給你的工作帶來的方便!
提示:在新版的CSS3標(biāo)準(zhǔn)中,attr()功能被擴(kuò)展,可以用在各種CSS標(biāo)記中。
使用counter()在列表中自動(dòng)添加序號(hào)
另外一個(gè)在CSS 2.1在就已經(jīng)支持的功能是counter(),使用它,你能方便的在頁(yè)面標(biāo)題,區(qū)塊和其它各種連續(xù)出現(xiàn)的頁(yè)面內(nèi)容上添加序號(hào)。有了它,你就不必限制于只能使用<ol>來實(shí)現(xiàn)這個(gè)效果,你可以更靈活的在頁(yè)面上使用自定義數(shù)字序列。
關(guān)鍵就是它真的很簡(jiǎn)單:在:before偽類里的content屬性加入counter():
CSS Code復(fù)制內(nèi)容到剪貼板
body {
countercounter-reset: heading;
新聞熱點(diǎn)
疑難解答
圖片精選