使用滤镜设置透明导致 IE 6/7/8/9 解析异常
一段代码:
?
?
红色所圈之处可以看到给div添加的内联样式width,height,background都依次排列。正常!
?
但给该div添加filter:alpha(opacity=20)后,
?
?
红色所圈之处看到,width和filter挤在一行上了。正常的情况width应该另起一行。
?
有人也许会说这只是开发者工具没有正确显示,只要不影响页面元素正确渲染即可。
?
的确,在IE6/7/8/9 中该元素宽度、高度、背景色及透明度都能按设置所期望的渲染,显示。如下图:
?
?
?
此外,将样式写在style标签内或css文件中也会出现以上现象。
?
?
既然渲染正常,那到底有什么问题呢?
?
稍等...
?
再看下JS设置filter,情况稍有不同。代码如下:
?
?IE中查看结构,效果如 图2,即filter和width在一行。
?
注意以上html中的最后一句js代码
?
图3:?
?
?
红色所圈之处看到四个css属性background、filter、height和width单独在一行显示。而没有像 图2 中filter和width在一行显示。
?
?
?
1 楼 i_love_sc 2011-01-16 filter:alpha(opacity=20);height:100px;background:gold;width:100px;
我把width放在最后面,也是出现width和opacity在一行的情况,很奇怪。 2 楼 zhouyrt 2011-01-16 i_love_sc 写道filter:alpha(opacity=20);height:100px;background:gold;width:100px;
我把width放在最后面,也是出现width和opacity在一行的情况,很奇怪。
的确。和width的位置无关。
用JS设置filter时建议在右括号后加个分号。目前JQ、EXT、Prototype和Mootools都没有加。 3 楼 ONEBOYS 2011-01-17 可以算做ie developer tools的bug吧

