论坛首页 入门技术论坛

使用滤镜设置透明导致 IE 6/7/8/9 解析异常

浏览 2271 次
该帖已经被评为新手帖
作者 正文
   发表时间:2011-01-15   最后修改:2011-01-15

一段代码:

<div style="width:100px;height:100px;background:gold"></div>

 
用IE开发者工具,或IE8自带的开发者工具。结构如 图1

 

图1

 

 

红色所圈之处可以看到给div添加的内联样式width,height,background都依次排列。正常!

 

但给该div添加filter:alpha(opacity=20)后,

<div style="filter:alpha(opacity=20);width:100px;height:100px;background:gold"></div>
 

情况发生了变化,如 图2

 

 

 

红色所圈之处看到,width和filter挤在一行上了。正常的情况width应该另起一行。

 

有人也许会说这只是开发者工具没有正确显示,只要不影响页面元素正确渲染即可。

 

的确,在IE6/7/8/9 中该元素宽度、高度、背景色及透明度都能按设置所期望的渲染,显示。如下图:

 

 

 

此外,将样式写在style标签内或css文件中也会出现以上现象。

 

 

既然渲染正常,那到底有什么问题呢?

 

稍等...

 

再看下JS设置filter,情况稍有不同。代码如下:

 

<!DOCTYPE HTML>
<html>
	<head>
		<meta charset="utf-8">
		<title>IE 6/7/8/9 中JS设置filter</title>
	</head>
	<body>
		<div id="d1" style="width:100px;height:100px;background:gold"></div>
		<script type="text/javascript">
			
			var d1 = document.getElementById('d1');
			d1.style.filter = 'alpha(opacity=20)';
			
		</script>
	</body>
</html>
 

IE中查看结构,效果如 图2 ,即filter和width在一行。

 

注意以上html中的最后一句js代码

 

d1.style.filter = 'alpha(opacity=20)';

 

右小括号后没有加分号。现在该句稍改下(的确是稍改,只加了个分号):

 

d1.style.filter = 'alpha(opacity=20);';

 

即在由小括号后加了个 分号 ";" 。 这时查看IE开发者工具如 图3

 

 

 

红色所圈之处看到四个css属性background、filter、height和width单独在一行显示。而没有像 图2 中filter和width在一行显示。

 

 

 

  • 大小: 8.9 KB
  • 大小: 8.9 KB
  • 大小: 376 Bytes
  • 大小: 11.7 KB
   发表时间:2011-01-16  
filter:alpha(opacity=20);height:100px;background:gold;width:100px;

我把width放在最后面,也是出现width和opacity在一行的情况,很奇怪。
0 请登录后投票
   发表时间: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都没有加。
0 请登录后投票
   发表时间:2011-01-17  
可以算做ie developer tools的bug吧
0 请登录后投票
论坛首页 入门技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics