溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

有哪些特別的CSS小技巧

發(fā)布時間:2021-09-28 15:51:19 來源:億速云 閱讀:93 作者:iii 欄目:web開發(fā)

這篇文章主要講解了“有哪些特別的CSS小技巧”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“有哪些特別的CSS小技巧”吧!

1.在CSS中用attr()顯示HTML屬性值

  attr()功能早在CSS 2.1標準中就已經(jīng)出現(xiàn),但現(xiàn)在才開始普遍流行。它提供了一個巧妙的方法在CSS中使用HTML標簽上的屬性,在很多情況下都能幫你省去了以往需要Javascript處理的過程。

  要想使用這個功能,你需要用到三種元素:一個:before 或 :after CSS偽類樣式, .content屬性,和一個帶有你想使用的HTML屬性名稱的attr()表達式。例如,想去顯示<h4>標題上的data-prefix屬性的值,你可以寫成這樣:

代碼如下:


h4:before {
   content: attr(data-prefix) " ";
   }
   <h4 data-prefix="Custom prefix">This is a heading</h4>

  顯然,這個例子并沒有展示它有多大用處,只是展示了它的基本用法。讓我們來試一個更有用的例子,attr()的一個極好的應用就是當用戶打印頁面時將頁面鏈接顯示出來。為了實現(xiàn)這個,你可以這樣寫:

代碼如下:


@media print {
   a:after {
   content: " (link to " attr(href) ") ";
   }
   }
   <a href="<a href="http://example.com">Visit">http://example.com">Visit</a> our home page</a>

  一旦你知道了這個技巧,你就會吃驚于很多時候它能給你的工作帶來的方便!

  提示:在新版的CSS3標準中,attr()功能被擴展,可以用在各種CSS標記中。

2.使用counter()在列表中自動添加序號

  另外一個在CSS 2.1在就已經(jīng)支持的功能是counter(),使用它,你能方便的在頁面標題,區(qū)塊和其它各種連續(xù)出現(xiàn)的頁面內容上添加序號。有了它,你就不必限制于只能使用<ol>來實現(xiàn)這個效果,你可以更靈活的在頁面上使用自定義數(shù)字序列。

  關鍵就是它真的很簡單:在:before偽類里的content屬性加入counter():

代碼如下:


body {
   counter-reset: heading;
   }</p> <p>    h5:before {
   counter-increment: heading;
   content: "Heading #" counter(heading) ".";
   }

  如果你想知道更多關于這個counter歸零和自增方法的知識,請參考關于這個主題的Mozilla Developer Network頁面。里面有個極好的如何使用嵌套counter的例子。

3.使用calc()做算術

  最后,但不是最不重要的,讓我們來說說calc()功能。這個函數(shù)能讓你執(zhí)行簡單的算術計算,例如計算元素的長寬,免去了你寫不易維護的Javascript代碼。這個函數(shù)支持所有簡單的基本算術運算,包括加減乘除。

  比方說,你想創(chuàng)建一個元素,使它的寬度占滿它的父元素,但還要留出一部分像素寬做其它用處:

代碼如下:


.parent {
   width: 100%;
   border: solid black 1px;
   position: relative;
   }
   .child {
   position: absolute;
   left: 100px;
   width: calc(90% - 100px);
   background-color: #ff8;
   text-align: center;
   }

感謝各位的閱讀,以上就是“有哪些特別的CSS小技巧”的內容了,經(jīng)過本文的學習后,相信大家對有哪些特別的CSS小技巧這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

css
AI