前端开发

 首页 > 前端开发 > css教程 > CSS currentColor 变量的使用 - html/css语言栏目:htm

CSS currentColor 变量的使用 - html/css语言栏目:htm

分享到:
【字体:
导读:
          CSS中存在一个神秘的变量,少有人知自然也不怎么为人所用。它就是crrentColor变量(或者说是CSS关键字,但我觉得称为变量好理解些)。初识它是何物?具有怎样的功效?它从哪里来?带...

CSS中存在一个神秘的变量,少有人知自然也不怎么为人所用。它就是crrentColor变量(或者说是CSS关键字,但我觉得称为变量好理解些)。
 
初识
 
它是何物?具有怎样的功效?它从哪里来?带着这些疑问我们继续。
 
下面是来自MDN的解释:
 
currentColor代表了当前元素被应用上的color颜色值。 使用它可以将当前这个颜色值应用到其他属性上,或者嵌套元素的其他属性上。
 
你这可以这么理解,CSS里你可以在任何需要写颜色的地方使用currentColor这个变量,这个变量的值是当前元素的color值。如果当前元素没有在CSS里显示地指定一个color值,那它的颜色值就遵从CSS规则,从父级元素继承而来。
 
到此似乎解决了上面三个哲学式的提问,但依然有些模糊。程序员之间的交流,还是上码才好。
 
场景1

约么?

p{
    color: red;
}
此时,

标签currentColor的值为red。

 
 
 
场景2
   

约么?

.container{
    color: #00ff00;
}
现在,我们没有给

标签指定颜色,它的color从父级容器也就是class为container的div继承而来,换句话说此时p标签的color为#00ff00,currentColor又是直接去取元素的color值,所以此时p标签的currentColor值也为#00ff00。

如果父级元素也没有写color呢?其实这里都还是CSS规则的范畴,跟本文的主角关系不太大。但本着不啰嗦会死的原则,就展开了讲。
 
如果父级元素也没有指定颜色,那它的父级元素就会从父级的父级去继承,直到文档的根结点html标签都还没显示指定一个颜色呢,就应用上浏览器默认的颜色呗~
 
   
        我来组成头部
   
   
       

约么?

   
   
战神金钢,宇宙的保护神!
/**
 * 无CSS
 */
 
 
那,这个时候的黑色其实是浏览器默认给的。此时p标签的currentColor自然也跟color值一样,为黑色,纯黑的#000。
 
如何用?
 
了解它是怎样的物品后,下面问题来了,如何用?有额外的buff效果么,耗蓝多么,CD时间长么。。。
 
前面说道,它就是一个CSS变量,存储了颜色值,这个值来自当前元素的colorCSS属性。当你需要为该元素其他属性指定颜色的时候,它就可以登上舞台了。
 
    好好说话,有话好好说
.container{
    color: #3CAADB;
    border: 4px solid currentColor;
}
 
这里我们第一次领略了currentColor的奇效。在指定边框颜色的时候,我们直接使用currentColor变量,而没有写一个传统的颜色值。
 
你似乎也知道了该如何用了。不只是border,其他能够使用颜色的地方,比如background,box-shadow等等。
 
带你装逼带你飞
 
新技能就是如此炫酷。大开脑洞任性地去使用吧!
 
与渐变混搭
 
你可能无法想象到的是,除了可以将currentColor用到普通需要颜色的场景,它同样可以被用在渐变中。
 
.container{
  height:200px;
  color: #3CAADB;
  background-image: linear-gradient(to right, #fff, currentColor 100%);
}
 
甚至也可用于填充svg,下面会有相应示例。
 
与CSS动画结合
 
当与CSS animation结合,可以得到更加有创意的效果,比如这个来自codepen的示例
 
 
更加简洁的CSS
 
其实,新技能不只是装逼那么单纯,合理的使用currentColor 变量会让你的CSS代码变得简洁。这才是我们想要达到的目的。以炫技为目的技能是没有生产意义的。
 
看下面这个例子(这个示例灵感来自这里)
 
 
 
我们在按钮中使用了一个svg图标。你是一个负责任的FE,所以,对这个按钮的各种状态:focus,:hover,:active都作了样式上的处理。同时,为了让图标也跟着保持一致的姿态变更,需要把对标签的样式处理同样就到到标签上。于是你的CSS代码看起来就是下面这样的了。
 
/*a 标签*/
.button {
    color: #117B6F;
    font-size: 1.2em;
}
.button:hover, .button:focus {
    color: #01B19A;
}
.button:active {
    color: #02D7BB;
}
 
/*svg 标签*/
.button svg {
    height: 17px;
    width: 17px;
    fill: #117B6F;
}
.button:hover svg, .button:focus svg {
    fill: #01B19A;
}
.button:active svg {
    fill: #02D7BB;
}
 
你也发现了,代码有点冗余。接下来,我们用currentColor来将它简化一下。于是成了下面这样:
 
/*a 标签*/
.button {
    color: #117B6F;
    font-size: 1.2em;
}
.button:hover, .button:focus {
    color: #01B19A;
}
.button:active {
    color: #02D7BB;
}
 
/*svg 标签*/
.button svg {
    height: 17px;
    width: 17px;
    fill: currentColor;
}
 
更好维护的CSS
 
仔细想想不难发现,当使用currentColor后,我们的CSS也变得更加好维护了。
 
还拿上面的按钮示例来说,优化之前不但代码冗余,而且哪天PM来劲了说这颜色饱看,给换个其他色。于是你得把标签和一起换了。
 
 
纯CSS实现tooltip提示框,CSS箭头及形状 ...
本片介绍仅用CSS做出tooltip那样的提示框及箭头等形状! 首先介绍一下CSS:after选择器 定义和用法:(参考w3school:after选择器)   :after选择器在被选元素的内容后面插入内容,使用content属性来指定要插入的内容 例: p:after { content:"台词:-"; background-color:yellow; color:red; font-weight...
CSS 3的display:盒类型详解 - html/css...
在CSS中,使用display属性来定义盒的类型。总体来说,盒类型分为两类:inline和block。如div默认是block,span默认是Inline。可以通过display修改默认的表现方式。 block and inline elements div { background:#aaff00; } span { background:#ffaa00; ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……