css透明度之rgba和opacity的区别及兼容

5次阅读

共计 1302 个字符,预计需要花费 4 分钟才能阅读完成。

对于设置透明度,我们有两个可以选的 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 属性

正文完
 0