關於CSS3中currentColor關鍵字的使用方法

來源:互聯網
上載者:User
這篇文章主要介紹了CSS3中currentColor關鍵字的妙用,合理地使用currentColor往往會讓CSS代碼更加簡潔,同時也能與SVG表徵圖很好地結合使用,需要的朋友可以參考下

初識

它是何物?具有怎樣的功效?它從哪裡來?帶著這些疑問我們繼續。

下面是來自MDN的解釋:

currentColor代表了當前元素被應用上的color顏色值。 使用它可以將當前這個顏色值應用到其他屬性上,或者嵌套元素的其他屬性上。

你這可以這麼理解,CSS裡你可以在任何需要寫顏色的地方使用currentColor這個變數,這個變數的值是當前元素的color值。如果當前元素沒有在CSS裡顯示地指定一個color值,那它的顏色值就遵從CSS規則,從父級元素繼承而來。

到此似乎解決了上面三個哲學式的提問,但依然有些模糊。程式員之間的交流,還是上碼才好。

情境1

<p>約嗎?</p>   p{       color: red;   }

此時,<p>標籤currentColor的值為red。

情境2

<p class="container">       <p>約嗎?</p>   </p>   .container{       color: #00ff00;   }

現在,我們沒有給<p>標籤指定顏色,它的color從父級容器也就是class為container的p繼承而來,換句話說此時p標籤的color為#00ff00,currentColor又是直接去取元素的color值,所以此時p標籤的currentColor值也為#00ff00。

情境3
如果父級元素也沒有寫color呢?其實這裡都還是CSS規則的範疇,跟本文的主角關係不太大。但本著不囉嗦會死的原則,就展開了講。

如果父級元素也沒有指定顏色,那它的父級元素就會從父級的父級去繼承,直到文檔的根結點html標籤都還沒顯示指定一個顏色呢,就應用上瀏覽器預設的顏色唄~

<!doctype html><html>    <head>        <title>我來組成頭部</title>    </head>    <body>        <p>約嗎?</p>    </body>    <footer>戰神金鋼,宇宙的保護神!</footer></html>/**    * 無CSS    */


那,這個時候的黑色其實是瀏覽器預設給的。此時p標籤的currentColor自然也跟color值一樣,為黑色,純黑的#000。

如何用?

瞭解它是怎樣的物品後,下面問題來了,如何用?有額外的buff效果麼,耗藍多麼,CD時間長麼。。。

前面說道,它就是一個CSS變數,儲存了顏色值,這個值來自當前元素的colorCSS屬性。當你需要為該元素其他屬性指定顏色的時候,它就可以登上舞台了。

<p class="container">       好好說話,有話好好說   </p>   .container{       color: #3CAADB;       border: 4px solid currentColor;   }


這裡我們第一次領略了currentColor的奇效。在指定邊框顏色的時候,我們直接使用currentColor變數,而沒有寫一個傳統的顏色值。

你似乎也知道了該如何用了。不只是border,其他能夠使用顏色的地方,比如background,box-shadow等等。
與漸層混搭

你可能無法想象到的是,除了可以將currentColor用到普通需要顏色的情境,它同樣可以被用在漸層中。

<p class="container">   </p>   .container{     height:200px;     color: #3CAADB;     background-image: linear-gradient(to rightright, #fff, currentColor 100%);   }

甚至也可用於填充svg,下面會有相應樣本。

currentColor 與SVG

我們可以使用 currentColor 來檢測元素當前使用的顏色,因而不需要定義 color 很多次。
結合 SVG 表徵圖使用時,currentColor 是很有用的,因為表徵圖顏色的改變取決於它們的父元素。通常我們是這麼做的:

.button {     color: black;   }   .button:hover {     color: red;   }   .button:active {     color: green;   }   .button svg {     fill: black;   }   .button:hover svg {     fill: red;   }   .button:active svg {     fill: green;   }

使用 currentColor 之後:

svg {       fill: currentColor;   }   .button {     color: black;     border: 1px solid currentColor;   }   .button:hover {     color: red;   }   .button:active {     color: green;   }

另一種方式是用於虛擬元素:

a {       color: #000;   }   a:hover {       color: #333;   }   a:active {       color: #666;   }   a:after,     a:hover:after,     a:active:after {       background: currentColor;     ...   }

以上就是本文的全部內容,希望對大家的學習有所協助,更多相關內容請關注topic.alibabacloud.com!

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.