这篇汇总主要是提供一些CSS不透明的详细介绍,代码示例和解释,以实现这项有用的CSS技术在您的项目中兼容所有浏览器。
关于CSS?透明度,有一点需要注意的是,它虽然使用了很多年,但它一直以来都不是一个标准属性。它是一种非标准技术,应该是CSS3规范的一部分。 一、旧的Opacity设置
第二行使用专用属性?-moz-opacity是?为了兼容Mozilla渲染引擎的早期版本,以及追溯到Netscape?Navigator。
Firefox?0.9以后就不要求使用-moz-opacity属性,Firefox?3.5(现在使用Gecko引擎)已经不在支持这个属性。 二、在Firefox,?Safari,?Chrome和Opera下的CSS透明度
上述语法将设置一个元素为70%不透明(或30%透明)。设置opacity:1将使元素不透明,而设置opacity:0将使得元素完全不可见。你?只要记住“opacity”等同于“不透明”就很容易记住了,opacity值越小就越接近透明。 三、IE下的CSS透明度
上面的CSS使用专用的filter属性来设置IE6-8透明度。对于IE6和IE7需要注意:为了使得透明设置生效,元素必须是“有布局”。一个
元素
可以通过使用一些CSS属性来使其被布局,有如width?和?position。关于微软专有的hasLayout属性详情,以及如何触发它,欢迎参考
52CSS.com相关文档。 #myElement?{??????filter:?progid:DXImageTransform.Microsoft.Alpha(opacity=40); 注意两行代码的不同之处:在第二行代码中,在filter属性前跟着-ms-前缀,并且属性值有加引号,这些都是语法所必须的。 四、使用JavaScript设置和改变CSS透明度
上面的代码可以使用行内循环或者其他动态函数递增修改透明度的值。当然,你必须先通过特征检测来决定使用哪一行代码。 五、使用JQuery设置和改变CSS透明度
不管元素的透明度在动画开始时是多少,它都会渐变到透明度为“.4”。动画的速度通过值“1000”设定,动画时间以毫秒为单位。代码中的最后一个属性是一个可选回调函数,将在动画完成后执行。 六、通过RGBA的透明度
在上面的定义中,通过RGB(前三个数字)给背景设定颜色,然后最后一个是alpha设置,以执行给定颜色的透明度。这个alpha设置跟opacity?属性一样,可设定任何0到1的数字,精确得到两位小数点。数字值越大,就越接近完全不透明的颜色。 七、通过?HSLA的透明度
更多关于HSLA颜色的解释,参考这篇来自W3.org的文章。如同RGBA透明度,最后的数字表示透明度设置,跟RGBA起同样的作用。注意
RGBA
和HSLA透明度的一个重要的好处是这些透明度设置不会影响到子元素的,但通过opacity属性的方式则会。alpha设置的RGBA和HSLA只影响
背景颜色的透明度,仅此而已。
以下代码是Firefox和Safari旧版本所需的透明度设置:
-khtml-opacity设置是针对旧版本的Webkit渲染引擎,这种专用属性现在已经过时了,除非你还有需要兼容Safari?1.x.的用户。
以下代码是除了IE外的所有当前浏览器的最简单,最最新的不透明度设置的CSS语法:
opacity属性可以精确地小数点后两位,所以值取“.01”和“.02”实际上是不同的,虽然可见度很难被发觉。一般情况下,精确到一位就可以了,取值如“.3”或“.7”。
IE下照旧有别于其他浏览器,并且目前也有三个不同版本的IE在广泛使用,透明度设置是不同的,有时需要额外的CSS来控制:
另外一个设置IE8的CSS透明度的方法语法如下(注意注释中指出的版本):
/*?第一行在IE6,?IE7和IE8下有效?*/
/*第二行仅在IE8下有效?*/}
说实在,有了如前一个例子中用alpha(opacity=40)的语法来作用于任何版本的IE下的任何有布局的元素之后,我也不确定是否还有必要用“progid”的方法。
您可以使用下面的语法访问JavaScript中的CSS?opacity?属性:
//?针对所有现代浏览器??document.getElementById(“myElement”).style.filter?=? ?”alpha(opacity=40)”;
//?针对IE
直接使用jQuery设置CSS透明度更直观更容易实现,因为在所有浏览器代码都一样,并且你不必担心在IE下元素是否“haslayout”:
您也可以使用一下jQuery代码使一个元素动画透明:
?$(“#myElement”).animate({??????opacity:?.4??????},?1000,?function()?{
//?动画完成,所有浏览器下有效??});
如果该元素的透明度在CSS中已经设定为“.4”,那在动画运行的时候,你将不会发觉有任何不同,所以动画开始和最终透明度要有所不同。
另一个CSS3技术只支持部分新的浏览器(Firefox?3+,?Opera?10.1+,?Chrome?2+,Safari?3.1+),可通过RGBA的alpha通道的方式设定。语法如下:
类似之前的定义,CSS3还允许使用HSLA单独设置颜色和alpha值,HSLA表示Hue(色调),?Saturation(饱和度),?Lightness(亮度),?和Alpha。以下是HSLA透明的例子:
详细解决方案
CSS透明技艺概总 Firefox/IE/Safari/Chrome/Opera
热度:1022 发布时间:2012-10-09 10:21:45.0
相关解决方案
- IE firefox 跟chrome执行js的区别
- Opera PMS 用户手册解决思路
- safari 浏览器 有时图片显示不全?需要刷新几次才好?该怎么解决
- chrome 如何查看url
- Chrome Javascript Click 事件,该如何解决
- chrome,fireFox获取绝对路径,该如何解决
- 关于图片下传前预览的有关问题-Firefox 8.0.1
- chrome 对JS 的一个代码不会弄!该怎么处理
- FireFox 上传文件,该如何处理
- firefox 中iframe 调用父窗口自定义函数如何写
- window.location.href 在 FireFox 3.0.3 下却不管用,有什么好的解决方法没有
- ie6 点击链接 不能形成下载,小弟我用ie7就可以,firefox 也可以
- FireFox <a title="title过长有有关问题">123</a> 的有关问题 title内容过长给切断用.替换
- Opera 支持iframe标记不?该怎么处理
- SAFARI 浏览器中出现的ajax的js异常
- firefox IE7 布局有关问题
- firefox 插件开发,javascript Number转NPVariant有关问题
- Firefox “上拉菜单”右键没有菜单
- safari 浏览器 confirm点击没反应解决办法
- Chrome 发出ajax请求无故多请求一次解决方法
- Software Engineer, Browser Applications (Firefox),该怎么解决
- Chrome 下发ajax请求无故多请求一次
- Firefox “下拉菜单”右键没有菜单?解决方案
- firefox 启动带参数程序解决方案
- safari 怎么替代xmlDOC 的loadXML方法
- safari 浏览器 confirm点击没反应,该怎么处理
- Firefox 中 TABLE 元素百分比宽度属性的有关问题
- 哪位高手能给个 win 下 firefox 3 的插件开发 sdk
- safari 中使用CSS 样式float的有关问题
- Firefox 访问故障解决方法