详解css透明度之rgba和opacity的区别及兼容
前端  /  管理员 发布于 7年前   190
对于设置透明度,我们有两个可以选的css3属性:rgba 和 opacity
opacity
用法:
#box{ background-color:rgb(125,25,0); opacity: 0.5}
IE9, Firefox, Chrome, Opera 和 Safari 使用属性 opacity 来设定透明度。
opacity 属性能够设置的值从 0.0 到 1.0。值越小,越透明。
IE8 以及更早的版本使用滤镜 filter:alpha(opacity=x)。x 能够取的值从 0 到 100。值越小,越透明。
所以如果项目为了要兼容IE8及以下,则需要写两段代码
#box{ background-color:rgb(125,25,0); opacity: 0.5; filter:alpha(opacity=50); /* 针对 IE8 以及更早的版本 */}
RGBA
用法:
#box{ background-color: rgba(0, 0, 0, .5);}
RGBA 颜色值是 RGB 颜色值的扩展,带有一个 alpha 通道 - 它规定了对象的不透明度。
RGBA 颜色值得到以下浏览器的支持:IE9+、Firefox 3+、Chrome、Safari 以及 Opera 10+。
RGBA 颜色值是这样规定的:rgba(red, green, blue, alpha)。alpha 参数是介于 0.0(完全透明)与 1.0(完全不透明)的数字。
那么对于IE8及以下需要做以下兼容:
#box{ filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr=#80000000,endColorStr=#80000000);}
其中:#88000000 的前两位数字控制透明度,取值16进制从00 -> FF(越小越透明),00表示完全透明,FF就是全不透明,后面六位是色值。
**※注意:
如果在IE9里面同时使用这RGBA两种方法时,会造成冲突而无法做到透明度的实现。
而对于opacity是可以两个一起写,没有冲突问题!**
opacity 和 rgba 的区别
为此我们设置了两个盒子来作为对比
html代码:
<div id="box1"> <div class="pane"></div> box1-opacity演示效果</div><div id="box2"> <div class="pane"></div> box2-rgba演示效果</div>
css代码:
#box1{ width: 100px; height: 100px; color:black; background-color:rgb(125,25,0); opacity: 0.5;}#box2{ margin-top: 10px; width: 100px; height: 100px; color:black; background-color: rgba(125,25,0, .5);}.pane{ width: 20px; height: 20px; background-color:red;}
结果如图:
从上面的结果我们可以看到 opacity 可以影响字体以及红色小方块的透明度,而 rgba 不会。
说明了子元素会继承父元素的 opacity 属性
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号