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 相关文章推荐
JavaScript高级程序设计阅读笔记(十六) javascript检测浏览器和操作系统-detect.js
Aug 14 Javascript
使用Java实现简单的server/client回显功能的方法介绍
May 03 Javascript
TypeScript 中接口详解
Jun 19 Javascript
javascript实现无缝上下滚动特效
Dec 16 Javascript
AngularJS控制器controller正确的通信的方法
Jan 25 Javascript
JavaScript中数组slice和splice的对比小结
Sep 22 Javascript
详解vue嵌套路由-params传递参数
May 23 Javascript
js异步编程小技巧详解
Aug 14 Javascript
element 结合vue 在表单验证时有值却提示错误的解决办法
Jan 22 Javascript
使用D3.js+Vue实现一个简单的柱形图
Aug 05 Javascript
实现Vue的markdown文档可以在线运行的方法示例
Dec 11 Javascript
layui 实现表格某一列显示图标
Sep 19 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 数据结构 算法 三元组 Triplet
2011/07/02 PHP
php简单开启gzip压缩方法(zlib.output_compression)
2013/04/13 PHP
自己写的php中文截取函数mb_strlen和mb_substr
2015/02/09 PHP
JavaScript 继承详解 第一篇
2009/08/30 Javascript
JQuery上传插件Uploadify使用详解及错误处理
2010/04/27 Javascript
学习javascript,实现插入排序实现代码
2011/07/31 Javascript
nodejs入门详解(多篇文章结合)
2012/03/07 NodeJs
jquery动态导航插件dynamicNav用法实例分析
2015/09/06 Javascript
轻松学习jQuery插件EasyUI EasyUI表单验证
2015/12/01 Javascript
jQuery+css实现的tab切换标签(兼容各浏览器)
2016/01/28 Javascript
设计模式中的facade外观模式在JavaScript开发中的运用
2016/05/18 Javascript
React Js 微信禁止复制链接分享禁止隐藏右上角菜单功能
2017/05/26 Javascript
JS实现微信摇一摇原理解析
2017/07/22 Javascript
微信小程序中post方法与get方法的封装
2017/09/26 Javascript
微信小程序实现简单表格
2019/02/14 Javascript
微信小程序蓝牙连接小票打印机实例代码详解
2019/06/03 Javascript
微信小程序聊天功能的示例代码
2020/01/13 Javascript
js实现html滑动图片拼图验证
2020/06/24 Javascript
[02:33]DOTA2英雄基础教程 司夜刺客
2013/12/04 DOTA
小小聊天室Python代码实现
2016/08/17 Python
Python随机数random模块使用指南
2016/09/09 Python
Python中关键字nonlocal和global的声明与解析
2017/03/12 Python
Python中pillow知识点学习
2018/04/30 Python
Python 利用scrapy爬虫通过短短50行代码下载整站短视频
2018/10/29 Python
python pygame实现2048游戏
2018/11/20 Python
详解python持久化文件读写
2019/04/06 Python
python打开windows应用程序的实例
2019/06/28 Python
用Python从0开始实现一个中文拼音输入法的思路详解
2019/07/20 Python
pytorch sampler对数据进行采样的实现
2019/12/31 Python
python3 kubernetes api的使用示例
2021/01/12 Python
HTML5仿手机微信聊天界面
2016/03/18 HTML / CSS
广州地球村科技数据库题目
2016/04/25 面试题
初一科学教学反思
2014/01/27 职场文书
2014年安全生产大检查方案
2014/05/13 职场文书
计算机专业毕业生自荐书
2014/06/02 职场文书
Python中基础数据类型 set集合知识点总结
2021/08/02 Python