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

对于设置透明度,我们有两个可以选的css3属性:rgba 和 opacity
opacity
用法:

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


IE9, Firefox, Chrome, Opera 和 Safari 使用属性 opacity 来设定透明度 。
opacity 属性能够设置的值从 0.0 到 1.0 。值越小,越透明 。
IE8 以及更早的版本使用滤镜 filter:alpha(opacity=x) 。x 能够取的值从 0 到 100 。值越小,越透明 。
所以如果项目为了要兼容IE8及以下,则需要写两段代码
详解css透明度之rgba和opacity的区别及兼容


RGBA
用法:
详解css透明度之rgba和opacity的区别及兼容


RGBA 颜色值是 RGB 颜色值的扩展,带有一个 alpha 通道 - 它规定了对象的不透明度 。
RGBA 颜色值得到以下浏览器的支持:IE9 、Firefox 3 、Chrome、Safari 以及 Opera 10。
RGBA 颜色值是这样规定的:rgba(red, green, blue, alpha) 。alpha 参数是介于 0.0(完全透明)与 1.0(完全不透明)的数字 。
那么对于IE8及以下需要做以下兼容:
详解css透明度之rgba和opacity的区别及兼容


【详解css透明度之rgba和opacity的区别及兼容】其中:#88000000 的前两位数字控制透明度,取值16进制从00 -> FF(越小越透明),00表示完全透明,FF就是全不透明,后面六位是色值 。
**※注意:
如果在IE9里面同时使用这RGBA两种方法时,会造成冲突而无法做到透明度的实现 。
而对于opacity是可以两个一起写,没有冲突问题!**
opacity 和 rgba 的区别
为此我们设置了两个盒子来作为对比
html代码:
详解css透明度之rgba和opacity的区别及兼容


css代码:
详解css透明度之rgba和opacity的区别及兼容


结果如图:
详解css透明度之rgba和opacity的区别及兼容


从上面的结果我们可以看到 opacity 可以影响字体以及红色小方块的透明度,而 rgba 不会 。
说明了子元素会继承父元素的 opacity 属性


    推荐阅读