最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

CSS3新属性currentColor的使用与兼容性介绍

来源:懂视网 责编:小采 时间:2020-11-02 22:08:31
文档

CSS3新属性currentColor的使用与兼容性介绍

CSS3新属性currentColor的使用与兼容性介绍:本章给大家说说CSS3新属性currentColor的使用以及currentColor属性的兼容性。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。currentColor顾名思意就是当前颜色,准确讲应该是当前的文字颜色,例如:.xxx { border:
推荐度:
导读CSS3新属性currentColor的使用与兼容性介绍:本章给大家说说CSS3新属性currentColor的使用以及currentColor属性的兼容性。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。currentColor顾名思意就是当前颜色,准确讲应该是当前的文字颜色,例如:.xxx { border:

本章给大家说说CSS3新属性currentColor的使用以及currentColor属性的兼容性。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

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代码:

更改颜色:<input id="colorInput" type="color" value="#34538b" autocomplete="off">
<p>
 <i class="icon icon1"></i><a href="##" class="link">返回</a>
 <i class="icon icon2"></i><a href="##" class="link">刷新</a>
 <i class="icon icon3"></i><a href="##" class="link">收藏</a>
 <i class="icon icon4"></i><a href="##" class="link">展开图片</a>
</p>

js代码:

var eleInput = document.getElementById("colorInput"),
 eleIcons = document.getElementsByTagName("i");
eleInput.onchange = function() { var i = 0, l = eleIcons.length; for (; i<l; i+=1) {
 eleIcons[i].style.backgroundColor = this.value;
 }
};

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

效果地址:http://www.zhangxinxu.com/study/201307/background-color-insert-background-image.html

那么现在使用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://www.zhangxinxu.com/wordpress/2014/10/currentcolor-css3-powerful-css-keyword/

文档

CSS3新属性currentColor的使用与兼容性介绍

CSS3新属性currentColor的使用与兼容性介绍:本章给大家说说CSS3新属性currentColor的使用以及currentColor属性的兼容性。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。currentColor顾名思意就是当前颜色,准确讲应该是当前的文字颜色,例如:.xxx { border:
推荐度:
标签: 用法 兼容 兼容性
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top