zoukankan      html  css  js  c++  java
  • 使用滤镜设置透明导致 IE 6/7/8/9 解析异常

    如下

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

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

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

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

    <div style="filter:alpha(opacity=20);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="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在一行显示。

    PS:很多流行JS库设置透明的方法没有加 alpha(opacity=20)后的分号。

  • 相关阅读:
    jmeter中生成不重复的序列
    jmeter返回解密
    jmeter请求加密
    查看链接设备和安装软件
    jmeter_事物控制器_Transaction Controller
    jmeter返回中提取匹配多个参数($1$$2$)
    jmeter官方文档地址
    DEDECMS会员注册如何配置邮箱发送邮件功能
    颤抖吧,Css3
    html embed用法
  • 原文地址:https://www.cnblogs.com/snandy/p/1977787.html
Copyright © 2011-2022 走看看