加入收藏 | 设为首页 | 会员中心 | 我要投稿 源码网 (https://www.900php.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 系统 > 正文

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

发布时间:2020-03-29 08:16:58 所属栏目:系统 来源:站长网
导读:对于设置透明度,我们有两个可以选的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。值越

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

(编辑:源码网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读