博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSS进阶篇--你用过css3的这个currentColor新属性吗?使用与兼容性
阅读量:6718 次
发布时间:2019-06-25

本文共 1492 字,大约阅读时间需要 4 分钟。

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

.xxx { border: 1px solid currentColor; }

currentColor表示“当前的标签所继承的文字颜色”,换种方式表示就是:currentColor = color的值。

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

当然可以使用css实现背景色镂空,可以方便控制图标的颜色。实现的原理是图标形状区域是透明镂空的,而周边是实色的。

CSS代码:

.icon {    display: inline-block;    width: 16px; height: 20px;    background-image: url(sprite_icons.png);    background-color: #34538b; /* 该颜色控制图标的颜色 */}.icon1 { background-position: 0 0; }.icon2 { background-position: -20px 0; }.icon3 { background-position: -40px 0; }.icon4 { background-position: -60px 0; }.link { margin-right: 15px; }

HTML代码:

更改颜色:

返回 刷新 收藏 展开图片

JS代码:

var eleInput = document.getElementById("colorInput"),    eleIcons = document.getElementsByTagName("i");eleInput.onchange = function() {    var i = 0, l = eleIcons.length;    for (; i

只需要改变背景图片的color就更改变图片的颜色。IE低版本也支持。

效果地址:

那么现在使用currentColor来实现这个效果:

.icon {    display: inline-block;    width: 16px; height: 20px;    background-image: url(../201307/sprite_icons.png);    background-color: currentColor; /* 该颜色控制图标的颜色 */}

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

.link:hover { color: #333; }/* 虽然改变的是文字颜色,但是图标颜色也一起变化了 */

说明:

border和box-shadow默认的颜色就是当前的文字颜色,也就是类似currentColor;

在iOS Safari浏览器下(iOS8)下,currentColor还是有一些bug的,例如伪元素hover时候,background:currentColor的背景色不会跟着变化,怎么办呢?等升级,或者使用border来模拟。

currentColor浏览器兼容情况:

支持的浏览器:谷歌,火狐,QQ浏览器,IE9+

不支持的浏览器:360,IE低版本浏览器

详细介绍请查看:

转载地址:http://fjjmo.baihongyu.com/

你可能感兴趣的文章
翻译中常见的单词4
查看>>
zabbix自定义触发器严重性
查看>>
无聊的时候,冷死了
查看>>
chkconfig命令详解
查看>>
SharePoint环境变更系列
查看>>
深入理解Java 8 Lambda(类库篇——Streams API,Collectors和并行)
查看>>
BLE广播数据包分析
查看>>
Zabbix监控进程日志的配置过程
查看>>
amoeba for mysql
查看>>
Linux系统账号安全应用
查看>>
我的友情链接
查看>>
nginx 访问默认index.html首页跳转指定页面
查看>>
NFS在CentOS6.2下的安装与配置
查看>>
MySQLCluster部署配置文档
查看>>
第十四讲 while网络刷博器爬虫
查看>>
电子邮件系统组成的5部分
查看>>
ReadWriteLock用法
查看>>
JavaScript调试技巧之console.log()详解
查看>>
RHEL7.x解决SSH登录慢
查看>>
linux下如何删除大量小文件
查看>>