IE9+已经不对document.createElement向下兼容的解决方法


Posted in Javascript onSeptember 14, 2015

今天发现某网站上,IE9和chrome中页面的功能居然有差异,于是在IE9下打开console,发现一堆js报错,用fiddler跟踪了一下,原来代码里有一句是这样的:

if(ie){
  var iframe = document.createElement('<iframe src="https://3water.com"></iframe>');
}

是的,问题就出在这里:DOM Exception: INVALID_CHARACTER_ERR (5)
因为在IE9里面,一些方法已经向w3c标准靠拢,和firefox、chrome浏览器等都保持了一致,包括这里的document.createElement方法。
因此,这里的代码需要改成:

if(ie && version < 9) {
  var iframe = document.createElement('<iframe src="https://3water.com"></iframe>');
} else {
  var iframe = document.createElement('iframe');
  iframe.setAttribute('src','https://3water.com');
}

不过,如果页面上加上了这个meta标签的话,能将IE9的文档模式强制降级到IE7:

<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7">

这样可以绕开这个BUG,不过我的建议是,如果页面上没有什么特殊的不能处理的,不要加这样的强制,会导致一些正常模式下不可控的现象。

在这里,我也顺便列几条我印象中的IE各个版本的差异性:

1、IE6
a、不支持png半透明图片,只能用filter实现
b、不支持css的max-width、max-height、min-width、min-height
其他不用说,一团糟,不过项目中还是得去兼容!

2、IE7
a、解决了png半透明图片的支持问题
b、解决了css的max-width、max-height、min-width、min-height支持
c、解决了css float导致的bug
d、增强了css选择器,比如,div节点也支持:hover伪类了
虽然解决了IE6的很多问题,不过IE7始终是一个中间产物,很多时候会出现让人摸不着头脑的样式问题,一般情况下,zoom:1是万能的

3、IE8
a、完全支持css2.1的选择器,向w3c看齐,逐步标准化
b、去掉了css中expression的支持,而增加-ms-的私有前缀
c、js方面,支持localStorage了
d、由于版本多,所以搞出了一个UA兼容模式:X-UA-Compatible

4、IE9
a、css3支持(部分)
b、html5支持(部分)
但是Javascript引擎换掉了,换成了chakra,性能很赞,同时也反映出:部分DOM操作已经不再向下兼容了。在这个时候,IE9已经实现w3c标准化了。

5、IE10
a、css3和html5的强支持
b、更多的-ms-私有属性(私有属性多了以后,会不会又走偏了?当然,这是chrome和firefox带头走偏的。。。各种私有属性!!!)

总之,咱们做前端的,就得跟着变化走,然后去适应这些变化。

Javascript 相关文章推荐
深入聊聊Array的sort方法的使用技巧.详细点评protype.js中的sortBy方法
Apr 12 Javascript
ImageFlow可鼠标控制图片滚动
Jan 30 Javascript
Js 本页面传值实现代码
May 17 Javascript
Jquery截取中文字符串的实现代码
Dec 22 Javascript
js 将json字符串转换为json对象的方法解析
Nov 13 Javascript
JS实现随机颜色的3种方法与颜色格式的转化
Jan 05 Javascript
小程序scroll-view安卓机隐藏横向滚动条的实现详解
May 16 Javascript
关于vue组件事件属性穿透详解
Oct 28 Javascript
vue el-tree 默认展开第一个节点的实现代码
May 15 Javascript
Vue微信公众号网页分享的示例代码
May 28 Javascript
javascript拖曳互换div的位置实现示例
Jun 28 Javascript
一篇文章弄清楚Ajax请求的五个步骤
Mar 17 Javascript
JS动态添加iframe的代码
Sep 14 #Javascript
javascript实现在指定元素中垂直水平居中
Sep 13 #Javascript
window.onload使用指南
Sep 13 #Javascript
JS+CSS简单树形菜单实现方法
Sep 12 #Javascript
纯js代码实现未知宽高的元素在指定元素中垂直水平居中显示
Sep 12 #Javascript
JS实现超精简响应鼠标显示二级菜单代码
Sep 12 #Javascript
JS+CSS实现的简单折叠展开多级菜单效果
Sep 12 #Javascript
You might like
php xml文件操作代码(一)
2009/03/20 PHP
php颜色转换函数hex-rgb(将十六进制格式转成十进制格式)
2013/09/23 PHP
ThinkPHP中url隐藏入口文件后接收alipay传值的方法
2014/12/09 PHP
Yii中srbac权限扩展模块工作原理与用法分析
2016/07/14 PHP
Yii2创建控制器(createController)方法详解
2016/07/23 PHP
PHP的RSA加密解密方法以及开发接口使用
2018/02/11 PHP
JS数学函数Exp使用说明
2012/08/09 Javascript
jQuery打印指定区域Html页面并自动分页
2014/07/04 Javascript
九种原生js动画效果
2015/11/11 Javascript
原生JavaScript实现滚动条效果
2020/03/24 Javascript
Jquery Easyui进度条组件Progress使用详解(8)
2020/03/26 Javascript
bootstrap实现图片自动轮播
2016/12/21 Javascript
JS正则表达式判断有效数实例代码
2017/03/13 Javascript
Element-UI中Upload上传文件前端缓存处理示例
2019/02/21 Javascript
详解在React项目中安装并使用Less(用法总结)
2019/03/18 Javascript
vue 实现cli3.0中使用proxy进行代理转发
2019/10/30 Javascript
JavaScript中的类型检查
2020/02/03 Javascript
在实例中重学JavaScript事件循环
2020/12/03 Javascript
用Python实现QQ游戏大家来找茬辅助工具
2014/09/14 Python
Python中的赋值、浅拷贝、深拷贝介绍
2015/03/09 Python
Python实现登录人人网并抓取新鲜事的方法
2015/05/11 Python
Python 装饰器使用详解
2017/07/29 Python
Python基于多线程实现ping扫描功能示例
2018/07/23 Python
windows10下安装TensorFlow Object Detection API的步骤
2019/06/13 Python
PyTorch 导数应用的使用教程
2020/08/31 Python
Html5页面中的返回实现的方法
2018/02/26 HTML / CSS
美国户外烹饪产品购物网站:Outdoor Cooking
2020/01/10 全球购物
夜大毕业自我鉴定
2013/10/11 职场文书
计算机专业毕业生自荐信
2013/12/31 职场文书
2015年质量管理工作总结范文
2015/05/18 职场文书
麦田里的守望者读书笔记
2015/06/30 职场文书
升职感谢领导的话语及升职感谢信
2019/06/24 职场文书
Python基础之教你怎么在M1系统上使用pandas
2021/05/08 Python
python文本处理的方案(结巴分词并去除符号)
2021/05/26 Python
postgresql无序uuid性能测试及对数据库的影响
2021/06/11 PostgreSQL
Python 数据科学 Matplotlib图库详解
2021/07/07 Python