zoukankan      html  css  js  c++  java
  • CSS currentColor 变量的使用

    CSS中存在一个神秘的变量,少有人知自然也不怎么为人所用。它就是crrentColor变量(或者说是CSS关键字,但我觉得称为变量好理解些)。

    初识

    它是何物?具有怎样的功效?它从哪里来?带着这些疑问我们继续。

    下面是来自MDN的解释

    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从父级容器也就是classcontainerdiv继承而来,换句话说此时p标签的color#00ff00currentColor又是直接去取元素的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属性。当你需要为该元素其他属性指定颜色的时候,它就可以登上舞台了。

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

    这里我们第一次领略了currentColor的奇效。在指定边框颜色的时候,我们直接使用currentColor变量,而没有写一个传统的颜色值。

    你似乎也知道了该如何用了。不只是border,其他能够使用颜色的地方,比如backgroundbox-shadow等等。

    带你装逼带你飞

    新技能就是如此炫酷。大开脑洞任性地去使用吧!

    与渐变混搭

    你可能无法想象到的是,除了可以将currentColor用到普通需要颜色的场景,它同样可以被用在渐变中。

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

    甚至也可用于填充svg,下面会有相应示例。

    与CSS动画结合

    当与CSS animation结合,可以得到更加有创意的效果,比如这个来自codepen的示例

    See the Pen currentColor by Scott Kellum (@scottkellum) on CodePen.

    更加简洁的CSS

    其实,新技能不只是装逼那么单纯,合理的使用currentColor 变量会让你的CSS代码变得简洁。这才是我们想要达到的目的。以炫技为目的技能是没有生产意义的。

    看下面这个例子(这个示例灵感来自这里

    我们在按钮中使用了一个svg图标。你是一个负责任的FE,所以,对这个按钮的各种状态:focus:hover:active都作了样式上的处理。同时,为了让图标也跟着保持一致的姿态变更,需要把对<a>标签的样式处理同样就到到<svg>标签上。于是你的CSS代码看起来就是下面这样的了。

    /*a 标签*/
    .button {
        color: #117B6F;
        font-size: 1.2em;
    }
    .button:hover, .button:focus {
        color: #01B19A;
    }
    .button:active {
        color: #02D7BB;
    }
    
    /*svg 标签*/
    .button svg {
        height: 17px;
         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;
         17px;
        fill: currentColor;
    }
    
    
    

    更好维护的CSS

    仔细想想不难发现,当使用currentColor后,我们的CSS也变得更加好维护了。

    还拿上面的按钮示例来说,优化之前不但代码冗余,而且哪天PM来劲了说这颜色饱看,给换个其他色。于是你得把<a>标签和<svg>一起换了。

    但优化后就不一样了,因为<svg>使用的填充是currentColor,你只需要改变<a>标签的颜色,它也就跟着变了。真正做到了牵一发而不动全身。这不正是众码友们毕生所追求的理想编程境界么。

    浏览器兼容性

    一提到浏览器兼容性,FE同学们或许就不敢那么任性了。之前你可能是这样的:

    当听到IE传来的噩耗,你可能是这样的:

    经查,can i use 没有关于它的数据。

    经测,

    • 本机Win7搭载的IE8不支持
    • 本机安装的火狐31发来战报表示支持
    • Chrome,你猜?
    • 本机Safari 5.1.7也表示支持
    • 本机Opera 26 同样表示支持

    根据这篇文章的描述,它是可以很好地工作在在所有现代浏览器和IE9+上的,甚至是各浏览器对应的移动版本。所以,在IE不是主要客户对象的情况下,还是可以放心使用的。

    参考

  • 相关阅读:
    框架-前端框架:layui
    开发模式-敏捷开发:什么是敏捷开发
    公司-便利蜂:便利蜂
    人物-IT-周鸿祎:百科
    公司-人人网:人人网
    未来-YLB-二手市场:二手市场
    未来-YLB-跳蚤市场:跳蚤市场(flea market)
    公司-浪潮:浪潮/inspur
    禁止CloudStack删除Xenserver原有虚拟机
    2.6.33中关于at91sam9260的i2c controller驱动的问题
  • 原文地址:https://www.cnblogs.com/jianxian/p/12711784.html
Copyright © 2011-2022 走看看