IE8下实现兼容rgba

昨天遇到一个问题,要实现一个背景透明的效果,用CSS3用rgba()就能实现,即css

background: rgba(0,0,0,.5);

可是要兼容到IE8,就发现没有透明效果,由于IE8不支持rgba()函数。下面咱们总结一下rgba()函数的含义。浏览器

rgba的含义,r表明red,g表明green,b表明blue,a表明透明度。红绿蓝是三原色,全部颜色均可以由这三种颜色拼合而成。好比rgba(0,0,0,.5)就是透明度为0.5的黑色。现代浏览器是支持rgba的,可是在IE8等古董级浏览器中是不支持rgba的,IE8只能勉强支持rgb()函数(即去掉了透明度,只能表示颜色)。函数

不过网上有这样的解法spa

background: rgb(0, 0, 0);    /*不支持rgba的浏览器*/
background: rgba(0,0,0,.5);  /*支持rgba的浏览器*/
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#7f000000,endColorstr=#7f000000);    /*IE8支持*/

第二句话的意思就是当上一行的透明度不起做用的时候执行。这句话的意思原本是用来作渐变的,可是这个地方不须要渐变。因此两个颜色都设置成了相同的颜色。code

解释下#7f000000,第一部分是#号后面的7f。是rgba透明度0.5的IEfilter值。从0.1到0.9每一个数字对应一个IEfilter值。对应关系以下:
图片描述
第二部分是19后面的六位。这个是六进制的颜色值。要跟rgb函数中的取值相同。好比rgb(0,0,0,)对应#000;都是黑色。orm

到这里,rgba的用法就能够兼容IE8了。blog

最近看到,不直接在样式里面添加filter,而是利用<!--[if IE]><![endif]-->来为ie添加filter兼容。在事后又发现IE9同时支持RGBA和filter,致使两个重叠,透明效果变差,因此须要改成<!--[if lt IE 9]><![endif]-->,
具体作法以下:图片

// 此方法感受略显麻烦,须要维护两个地方的代码。改成下方作法
<!--[if lt IE 9]>

   <style type="text/css">

   .color-block {
       background:transparent;
       filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#7f000000,endColorstr=#7f000000);
       zoom: 1;
    }

    </style>

<![endif]-->

IE9同时支持RGBA和filter,会致使两个重叠,透明效果异常。有网友评论,建议用 :root 来去除 ie9+ 浏览器的 filter,也是很不错的办法,在此改成如下作法it

.color-block {
        background: rgb(0, 0, 0);    /*不支持rgba的浏览器*/
        background: rgba(0,0,0,.5);  /*支持rgba的浏览器*/
        filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#7f000000,endColorstr=#7f000000); 
    }
    
    :root .color-block {
        filter: none;
    }
相关文章
相关标签/搜索