返回顶部
首页 > 资讯 > 前端开发 > VUE >CSS中currentColor关键字如何使用
  • 385
分享到

CSS中currentColor关键字如何使用

2024-04-02 19:04:59 385人浏览 泡泡鱼
摘要

这篇文章给大家介绍CSS中currentColor关键字如何使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、currentColor-真正大隐于市者实际上,之前“SVG图标颜色文

这篇文章给大家介绍CSS中currentColor关键字如何使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

一、currentColor-真正大隐于市者

实际上,之前“SVG图标颜色文字般继承与填充”一文就简单介绍过currentColor, 后来有同事问此关键字,说没见过。我意识到,应该好好大家宣扬currentColor一番。

currentColor顾名思意就是“当前颜色”,准确讲应该是“当前的文字颜色”,例如:

CSS Code复制内容到剪贴板

  1. .xxx { border: 1px solid currentColor; }   

没错!再说一遍,没错!就是这么一个长得很不和谐的单词就是css3中一个标准且重要且强大的关键字。

什么?你没见过!!孤陋寡闻了吧~~过来~~来嘛~~只告诉你一个人哦,鄙人其实……已经使用有一段时日了,超赞的!

没事没事,别慌,现在开始认识还来得急,也会让你爽滴!
二、currentColor的使用与表现

上面提到,currentColor表示“当前的标签所继承的文字颜色”。可能还有小伙伴一时半会没消化过来,炒两个简单板栗助消化,CSS代码如下:

CSS Code复制内容到剪贴板

  1. img[src$='mm1.jpg'] { border: 1em solid currentColor; }  

于是,如果御用妹子直接暴露在本文中,妹子边框颜色就会是文章默认文字颜色,如下这样子:
CSS中currentColor关键字如何使用

我的鑫空间<pre>标签文字颜色是蓝色(pre { color: blue; }),于是,我把御用妹子放在<pre>标签中,则边框则是蓝色,如下:
CSS中currentColor关键字如何使用

注意:由于是CSS3新增关键字,需要IE9+以及其他现代浏览器才有效果。

换种方式表示就是:currentColor = color的值

用图示意是:
CSS中currentColor关键字如何使用

任意替换性
凡事需要使用颜色值的地方,都可以使用currentColor替换,比方说背景色 &ndash; background-color, 渐变色 &ndash; gradient, 盒阴影 &ndash; box-shadow, SVG的填充色 &ndash; fill等等。很灵活,很好用!

下面问题来了,我要让图片边框蓝色,直接:

CSS Code复制内容到剪贴板

  1. border: 1em solid blue;  

不就好了,还要费尽周折弄个currentColor搞摩斯(武汉话,&rsquo;干嘛&rsquo;意思)啊?这活生生多了好多字节的大小啊!

这个想法其实短见了,当我们应用一些CSS高级技能,尤其CSS3图形技术的时候,你会发现,currentColor就是雾霾天气下的强劲冷空气,带来无比的清爽与洁净,下面一章节的栗子大家不妨好好感受下!
三、 currentColor的实战表演秀

实战1:背景色镂空技术
去年介绍过“CSS背景色镂空技术”,可以方便控制图标的颜色,很赞的想法。此文章对应demo可以轻戳这里访问。

这种设计的目的就是鼠标hover时候,图标可以跟着文字一起变色。如果不考虑兼容性问题,我们可以稍稍改造下,使其实现更加简单:

CSS Code复制内容到剪贴板

  1. .icon {   

  2.     display: inline-block;   

  3.     width: 16px; height: 20px;   

  4.     background-image: url(../201307/sprite_icons.png);   

  5.     background-color: currentColor;   

  6. }  

于是,我们想要鼠标hover文字链接,其图标颜色要跟着一起变化,只要改变文字颜色就可以了:

CSS Code复制内容到剪贴板

  1. .link:hover { color: #333; }  

html结构如下:

XML/HTML Code复制内容到剪贴板

  1. <a href="##" class="link"><i class="icon icon1"></i>返回</a>  

于是鼠标hover就是#333颜色图文合体变化:
CSS中currentColor关键字如何使用

您可以狠狠地点击这里:背景色镂空技术与currentColor demo

实战2:CSS3图标生成与hover控制
今天开春时候写过有一定反响的“CSS3图标图形生成技术个人攻略”一文,那个时候还没有意识到可以借助CSS3 currentColor简化工作量和HTML代码。现在可以使用同样的例子感受下currentColor的风采。

所谓CSS3图标生成,就是图标完全由CSS3特性代码组合合成。由于多半跟链接文字混用,因此,有个交互效果就是:hover文字的时候,图标的颜色也要跟着变化。我一开始使用的是定值颜色,为了hover时候颜色控制方便,就大肆使用border属性构建图形,虽然效果也有,但HTML和CSS都啰嗦了点。借助currentColor, hover时候的颜色变化,我们根本无需关心,因为无论是border, background, 还是box-shadow都使用currentColor作为图形颜色,hover时候自然就会变成我们想要的文字颜色。

于是,之前文章demo中下图这些CSS代码就多余了:
CSS中currentColor关键字如何使用

具体每个图标代码也简化了,拿平铺图标举例,9个点:
CSS中currentColor关键字如何使用

之前为了hover方便,使用border实现,于是5个元素上阵才模拟出来的,代码熙熙攘攘如下:

CSS Code复制内容到剪贴板

  1. .ico-repeat::before,   

  2. .ico-repeat::after,   

  3. .ico-repeat z { width: 3px; height: 7px; border-top: 3px solid #777; border-bottom: 3px solid #777; top: 5px; left: 3px; }   

  4. .ico-repeat::before { left: 3px; }   

  5. .ico-repeat::after { left: 13px; }   

  6. .ico-repeat z { left: 8px; }   

  7. .ico-repeat z::before { width: 7px; height: 3px; border-left: 3px solid #777; border-right: 3px solid #777; top: 2px; left: -5px; }   

  8. .ico-repeat z::after { width: 3px; border-top: 3px solid #777; top: 2px; }   

使用currentColor我们可以摆脱实现方式的限制,例如,我们可以使用box-shadow + currentColor, 只要一个元素就可以了。

CSS Code复制内容到剪贴板

  1. .ico-repeat::before { width: 3px; height: 3px; background-color: currentColor; box-shadow: 0 5px currentColor, 5px 0 currentColor, 5px 5px currentColor, 10px 0 currentColor, 0 10px currentColor, 5px 10px currentColor, 10px 5px currentColor, 10px 10px currentColor; top: 5px; left: 3px; }  

HTML方便也没有必要再内嵌一个<z>元素,直接如下就可以了:

XML/HTML Code复制内容到剪贴板

  1. <a href="javascript:" class="ico-a"><i class="ico ico-repeat"></i>平铺</a>  

鼠标hover效果依然杠杠的,如下:
CSS中currentColor关键字如何使用

其他很多图标也可以做类似的优化,例如列表图标可以放心使用background-color + border + background-clip单标签三边框生成技术,于是,只要两个元素就足够了,而之前至少要四个。

若想感受,您可以狠狠地点击这里:CSS3图标图形生成与currentColor demo
四、结语,体系中方能彰显强大

在CSS2.1的年代,虽然没有currentColor, 我们依然可以该蹦蹦该跳跳,因为,那时候图形这些东西都是交给图片完成的。但是,CSS3(以及SVG)的强大特性、硬件发展(屏幕)以及设计趋势赋予了其新的使命,图形构建就是其中之一。然而,阻碍之一就是如何方便控制图形的状态变化,幸好,我们有currentColor,图形跟随文字颜色状态同时变化,达到了「图文合一」的境界,这种境界已经超越font-face, 必将在未来的WEB技术大潮中大放异彩!

关于CSS中currentColor关键字如何使用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: CSS中currentColor关键字如何使用

本文链接: https://lsjlt.com/news/75166.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • CSS中currentColor关键字如何使用
    这篇文章给大家介绍CSS中currentColor关键字如何使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、currentColor-真正大隐于市者实际上,之前“SVG图标颜色文...
    99+
    2024-04-02
  • CSS3中currentColor关键字如何使用
    本篇文章为大家展示了CSS3中currentColor关键字如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。场景1CSS Code复制内容到剪贴板<p&...
    99+
    2024-04-02
  • SQLite中Autoincrement关键字如何使用
    这篇文章给大家介绍SQLite中Autoincrement关键字如何使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。SQLite 的 AUTOINCREMENT 是一个关键字,用于表...
    99+
    2024-04-02
  • ES6中class关键字如何使用
    这篇文章将为大家详细讲解有关ES6中class关键字如何使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1 、介绍   //...
    99+
    2024-04-02
  • VBS中如何使用Me关键字
    这篇文章将为大家详细讲解有关VBS中如何使用Me关键字,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。VBS 是一种很简单的脚本语言,正因为简单,所以仅仅支持面向对象的很小一部分特性。 其他面...
    99+
    2023-06-08
  • VBS中如何使用Default关键字
    今天就跟大家聊聊有关VBS中如何使用Default关键字,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。其实 MSDN 的 VBScript 文档中关于 Function 和 Sub ...
    99+
    2023-06-08
  • ASP.NET中static关键字如何使用
    ASP.NET中static关键字如何使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。静态变量当我们编写一个类时,其实就是在描述其对象的属性和行为,而并没有产生实质上的对...
    99+
    2023-06-17
  • C# 中default关键字如何使用
    本篇文章给大家分享的是有关C# 中default关键字如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。C# default关键字可在switch语句或泛型代码中使用。sw...
    99+
    2023-06-17
  • java中static关键字如何使用
    java中static关键字如何使用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。public class Parent {  ...
    99+
    2023-06-20
  • PHP中final关键字如何使用
    今天就跟大家聊聊有关PHP中final关键字如何使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在PHP中类的继承是使用最多的一个编程特性,我们可以创建一个基类(父类)然后在这其中...
    99+
    2023-06-17
  • C++ 中如何使用static关键字
    C++ 中如何使用static关键字,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、静态全局变量在全局变量前,加上C++ static关键字,该变量就被定义成...
    99+
    2023-06-17
  • C++中如何使用 explicit关键字
    这期内容当中小编将会给大家带来有关C++中如何使用 explicit关键字,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。C++ explicit关键字用来修饰类的构造函数,表明该构造函数是显式的,既然有&...
    99+
    2023-06-17
  • VB.NET中Patial关键字如何使用
    VB.NET中Patial关键字如何使用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。VB.NET Patial关键字允许您将很长的类分解成多个物理源文件。今天...
    99+
    2023-06-17
  • Java中如何使用final关键字
    Java中如何使用final关键字,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 一.final关键字的基本用法  在Java中,final关键字可以用来修饰类、方法和变量...
    99+
    2023-06-19
  • Java中如何使用instanceof关键字
    这篇“Java中如何使用instanceof关键字”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“Java中如何使用instanceof关键字”,小编整理了以下知识点,请大家跟着小编的步伐一步一...
    99+
    2023-06-29
  • java中throws关键字如何使用
    在Java中,throws关键字用于在方法签名中声明可能抛出的异常。它用于告诉调用该方法的代码,该方法可能会抛出特定类型的异常,调用...
    99+
    2023-09-12
    java
  • Dockerfile中VOLUMES关键字如何使用
    这篇文章将为大家详细讲解有关Dockerfile中VOLUMES关键字如何使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。我有一个如下的Dockerfile:定义了一个名为log的VOLU...
    99+
    2023-06-04
  • Replace关键字如何使用
    本篇文章为大家展示了Replace关键字如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。在sql server中Replace关键字主要是用来将字符...
    99+
    2024-04-02
  • SQL Server中如何使用Apply关键字
    SQL Server中如何使用Apply关键字,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、概念介绍APPLy关键字是SQLServe...
    99+
    2024-04-02
  • 如何在Java中使用synchronized关键字
    如何在Java中使用synchronized关键字?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。java基本数据类型有哪些Java的基本数据类型分为:1、整数类...
    99+
    2023-06-14
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作