您的位置:首页 > Web前端 > > 正文

css用什么设置透明度(详解css透明度之rgba和opacity的区别及兼容)

更多 时间:2022-03-31 00:28:24 类别:Web前端 浏览量:1729

css用什么设置透明度

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

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

  • <li id="box1">
        <li class="pane"></li>
        box1-opacity演示效果
    </li>
    <li id="box2">
        <li class="pane"></li>
        box2-rgba演示效果
    </li>
    
  • 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;
    }
    
  • 结果如图:

    css用什么设置透明度(详解css透明度之rgba和opacity的区别及兼容)

    从上面的结果我们可以看到 opacity 可以影响字体以及红色小方块的透明度,而 rgba 不会。

    说明了子元素会继承父元素的 opacity 属性

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。