:before和:after偽類元素創造神奇效果

來源:互聯網
上載者:User

文章簡介:偽類元素之美.

通過使用:before和:after,你能創作出讓人稱奇的視覺效果。對頁面中的每個元素,你都有兩個額外的可以控制的元素,本來這些是需要額外的元素來實現。他們給設計帶來了更多的趣味性的空間,而不是增加無語義的有負面影響的標籤。這裡給大家整理了一堆讓人稱奇的東西。讓我們開始吧!

給了你多層背景畫布


因為你可以相對於他們的父元素絕對位置偽類元素,你可以把他們想象他們是每個元素的兩個額外層。Nicolas Gallagher shows us 給我們展示了很多這種應用,包括多層的邊框,結合css3的多重背景和等高列。

擴充通過單一元素表現更多圖形的可能


所有上面的圖形any many more都可以通過一個單一的元素創造出來,這是一個很現實的方法。和“make a coffee cup with pure CSS!”的這類案例相反(使用了1700的div),這種方法更加實用。
下面是這段代碼可以讓我們得到六角星的例子:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 #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; }

將連結文字的連結地址列印出來

1 2 3 4 5 @media print {   a[href]:after {     content: " (" attr(href) ") ";   } }

清除浮動


和增加而外的沒有語義的標籤來清除容器浮動相比,我們可以使用偽類元素來為我們做這件事情。就是我們熟悉的“clearfix”,和另外一個更有語義的被命名為類名“group”。

1 2 3 4 5 6 7 8 9 10 11 .group:before, .group:after {     content:"";     display:table; } .group:after {     clear:both; } .group {     zoom:1; /* For IE 6/7 (trigger hasLayout) */ }

類比置中浮動


浮動屬性中實際上並不包含置中的值,除非我們自己希望有這個屬性。浮動雖然有左和右屬性,但是通過佔位的偽類元素我們可以在兩列布局中間開闢出一個地區放一張圖片,我們可以類比出這種效果simulate the effect。

表示出區塊中代碼使用的是哪種語言


你現在正在使用的這個網站,通過偽類元素標示出了代碼塊她是用哪種語言。

1 <pre rel="CSS"></pre>
1 2 3 4 5 6 pre:after {   content: attr(rel);   position: absolute;   top: 22px;   right: 12px; }

創造一系列表徵圖


Nicolas Gallagher 再次通過不使用圖片的情況下,拓展了上面的想法創造了另一個層次的a massive set of iconsIcon,最多隻有兩個偽類元素。

更有效使用空間


CSS帶來的,CSS也能帶走。這句話的意思是偽類元素內容可以通過媒體查詢applied or removed conditionally via media queries。或許你可以在空間充裕的情況下使用Icon,當空間充裕的時候使用更有描述性的文字。

使用更有裝飾性的排版


如果你的偽類元素是文字,他們將會繼承他們父類元素的排版樣式。但是當你設定內容時,你也可以對它們使用樣式。也就是說,你可以使用不同的字型和顏色讓你的標題更有裝飾效果。

1 2 3 4 5 6 7 8 9 10 11 12 13 14 h2 {      text-align: center; } h2:before, h2:after {     font-family: "Some cool font with glyphs", serif;     content: "\00d7";  /* Some fancy character */     color: #c83f3f; } h2:before {     margin-right: 10px; } h2:after {     margin-left: 10px; }

創造瀏覽器寬度的條


當你需要元素,它的內容很很少,但是你需要它的背景可以填充整個寬度,你通常採用的做法是追加一個沒有語義的內部包含容器,或者使用一個可以重複空間定義。或者你可以通過使用一個元素,將他的偽類元素延伸到邊緣。simulate the effect

給 body 標籤加邊框


想在頁面的左右增加一個規則的邊框,並使用固定位置的偽類元素將條定義在頭部和頂部,我們可以使用“body border” effect而並不需要使用額外的標籤。

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 body:before, body:after {     content: "";     position: fixed;     background: #900;     left: 0;     right: 0;     height: 10px; } body:before {     top: 0; } body:after {     bottom: 0; } body {     border-left: 10px solid #900;     border-right: 10px solid #900; }

製作有發光的按鈕


如果你使用塊偽類元素,並讓它們有從透明到白色,並將他們定位到按鈕之外(通過overflow隱藏),當滑鼠懸浮的時候通過使用動畫效果你就會發現按鈕有了光感。這個效果你可以在 Firefox4 或者 Firefox5使用了,因為這是目前唯一允許給偽類元素增加動畫效果的瀏覽器。

Anton Trollbäck製作的原始版 Nicolas Gallagher 的偽類元素最佳化版; 我的另一個版本

當特殊連結觸發時,頁面漸隱


如果你沒有設定一個相對屬性來定位一個元素,絕對位置的偽類元素將會被定位在它的設定相對定位的父級元素。如果沒有其它的元素,那它就會相對於它的根項目。你可以通過它創造一個充滿瀏覽器視窗的元素,把它放在主要元素的下面,這樣我們就能通過連結創造一種“頁面漸隱的效果”。

讓標題看上去像絲帶般的立體效果


每個人都喜歡絲帶!看看通過html和css創造的絲帶Check out this snippet。這使用了一點 z-index負值的形式,這在有些時候需要一個額外的容器元素去防止下面的偽類元素在一個透明的背景之下。

修飾有序表單的數字列表


你是不是曾經試圖給有序表單的數字定義樣式?你可能會把這些數字包在一個span標籤內,並給他們定義樣式,但是當我們移除span的樣式的時候就亂掉了。或者我們還可能使用更瘋狂的方法,用數字圖片當背景。或者移除表單樣式去掉,使用你自己的數字。諸如種種。更好的方法是使用偽類元素來做這件事情pseudo elements as counters。

讓資料表單有更好的適用性


用小螢幕看一個大的資料表單是一個噩夢。不僅是放大還是需要垂直或者水平滾動,並且當他們縮小的時候他們會變得太小而無法閱讀。我們可以通過使用CSS 媒體查詢使用偽類元素來重新格式化它們,使其在小螢幕上讓他們有更強的可閱讀性make the data table responsive。

創造樣式化的提示


使用HTML5的data屬性,然後將這些屬性取出來,樣式化後放到偽類元素裡面,我們可以通過create completely custom tooltipscss創造完整的定製提示。

中文原文:偽類元素之美
英文原文:A Whole Bunch of Amazing Stuff Pseudo Elements Can Do



相關文章

Alibaba Cloud 10 Year Anniversary

With You, We are Shaping a Digital World, 2009-2019

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。