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


Posted in Javascript onApril 07, 2011

如下

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

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

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

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

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

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

情况发生了变化,如 图2 :

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

红色所圈之处看到,width和filter挤在一行上了。正常的情况width应该另起一行。
有人也许会说这只是开发者工具没有正确显示,只要不影响页面元素正确渲染即可。
的确,在IE6/7/8/9 中该元素宽度、高度、背景色及透明度都能按设置所期望的渲染,显示。如图:

使用滤镜设置透明导致 IE 6/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 :

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

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

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

Javascript 相关文章推荐
ExtJS Grid使用SimpleStore、多选框的方法
Nov 20 Javascript
跟着Jquery API学Jquery之一 选择器
Apr 07 Javascript
js jquery ajax的几种用法总结(及优缺点介绍)
Jan 28 Javascript
javascript判断office版本示例
Apr 11 Javascript
js+css实现有立体感的按钮式文字竖排菜单效果
Sep 01 Javascript
浅析JavaScript中命名空间namespace模式
Jun 22 Javascript
JavaScript中setter和getter方法介绍
Jul 11 Javascript
vue 界面刷新数据被清除 localStorage的使用详解
Sep 16 Javascript
vue-cli3项目展示本地Markdown文件的方法
Jun 07 Javascript
Jquery Datatables的使用详解
Jan 30 jQuery
在VUE style中使用data中的变量的方法
Jun 19 Javascript
如何利用JavaScript实现二叉搜索树
Apr 02 Javascript
javascript各浏览器中option元素的表现差异
Apr 07 #Javascript
IE6/7/8中Option元素未设value时Select将获取空字符串
Apr 07 #Javascript
我的javascript 函数链之演变
Apr 07 #Javascript
JavaScript中链式调用之研习
Apr 07 #Javascript
js中各浏览器中鼠标按键值的差异
Apr 07 #Javascript
javascript 单例/单体模式(Singleton)
Apr 07 #Javascript
Safari5中alert的无限循环BUG
Apr 07 #Javascript
You might like
《PHP编程最快明白》第二讲 数字、浮点、布尔型、字符串和数组
2010/11/01 PHP
win7安装php框架Yii的方法
2016/01/25 PHP
session 加入redis的实现代码
2016/07/15 PHP
php记录搜索引擎爬行记录的实现代码
2018/03/02 PHP
PHP chr()函数讲解
2019/02/11 PHP
解决css和js的{}与smarty定界符冲突问题的两种方法
2013/09/10 Javascript
jQuery中DOM树操作之复制元素的方法
2015/01/23 Javascript
JavaScript中文件上传API详解
2016/04/01 Javascript
Node.js DES加密的简单实现
2016/07/07 Javascript
js变量提升深入理解
2016/09/16 Javascript
为输入框加入数字js校验代码分享
2017/11/02 Javascript
JS实现简单的浮动碰撞效果示例
2017/12/28 Javascript
在create-react-app中使用css modules的示例代码
2018/07/31 Javascript
Node.js模拟发起http请求从异步转同步的5种用法
2018/09/26 Javascript
mock.js实现模拟生成假数据功能示例
2019/01/15 Javascript
详解小程序设置缓存并且不覆盖原有数据
2019/04/15 Javascript
vue限制输入框只能输入8位整数和2位小数的代码
2019/11/06 Javascript
[02:12]打造更好的电竞完美世界:完美盛典回顾篇
2018/12/19 DOTA
Python对字符串实现去重操作的方法示例
2017/08/11 Python
Python异常处理操作实例详解
2018/08/28 Python
Python3爬虫使用Fidder实现APP爬取示例
2018/11/27 Python
python scrapy爬虫代码及填坑
2019/08/12 Python
From CSV to SQLite3 by python 导入csv到sqlite实例
2020/02/14 Python
Django+boostrap 美化admin后台的操作
2020/03/11 Python
HTML+CSS3模拟心的跳动实例代码
2017/09/05 HTML / CSS
Shopee印度尼西亚:东南亚与台湾市场最大电商平台
2018/06/17 全球购物
营销专业应届生求职信
2013/11/26 职场文书
民族团结先进集体事迹材料
2014/05/22 职场文书
校优秀毕业生主要事迹
2014/05/26 职场文书
幼儿园清明节活动总结
2014/07/04 职场文书
安全在我心中演讲稿
2014/09/01 职场文书
英语辞职信范文
2015/02/28 职场文书
教师求职自荐信范文
2015/03/04 职场文书
酒店收银员岗位职责
2015/04/07 职场文书
人生遥控器观后感
2015/06/11 职场文书
如何用python反转图片,视频
2021/04/24 Python