CSS的第一个变量,它就是crrentColor
。
初识
currentColor
代表了当前元素被应用上的color
颜色值。 使用它可以将当前这个颜色值应用到其他属性上,或者嵌套元素的其他属性上。
CSS里你可以在任何需要写颜色的地方使用currentColor
这个变量,这个变量的值是当前元素的color
值。如果当前元素没有在CSS里显示地指定一个color
值,那它的颜色值就遵从CSS规则,从父级元素继承而来。
- 场景1
<p>约么?</p>
p{
color: red;
}
此时,<p>
标签currentColor
的值为red
。
- 场景2
<div class="container">
<p>约么?</p>
</div>
.container{
color: #00ff00;
}
现在,我们没有给<p>
标签指定颜色,它的color
从父级容器也就是class
为container
的div
继承而来,换句话说此时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>
那,这个时候的黑色其实是浏览器默认给的。此时p
标签的currentColor
自然也跟color
值一样,为黑色,纯黑的#000
。
如何用?
了解它是怎样的物品后,下面问题来了,如何用?有额外的buff
效果么,耗蓝多么,CD时间长么。。。
前面说道,它就是一个CSS变量,存储了颜色值,这个值来自当前元素的color
CSS属性。当你需要为该元素其他属性指定颜色的时候,它就可以登上舞台了。
<div class="container">
好好说话,有话好好说
</div>
.container{
color: #3CAADB;
border: 4px solid currentColor;
}
这里我们第一次领略了currentColor
的奇效。在指定边框颜色的时候,我们直接使用currentColor
变量,而没有写一个传统的颜色值。
你似乎也知道了该如何用了。不只是border
,其他能够使用颜色的地方,比如background
,box-shadow
等等。