JavaScript 浏览器兼容性总结及常用浏览器兼容性分析


Posted in Javascript onMarch 30, 2016

本文是三水点靠木小编日常整理些关于js兼容性问题,及IE与Firefox等常用浏览器的兼容性分析,对js浏览器兼容性相关知识感兴趣的朋友一起学习吧!

1. children与childNodes

IE提供的children、childNodes和firefox下的childNodes的行为是有区别的,firefox下childNodes会把换行和空白字符都算作父节点的子节点,而IE的childNodes和children不会。比如:

<div id="dd">
<div>yizhu2000</div>
</div>

d为dd的div在IE下用childNodes查看,其子节点数为1,而ff下为三,我们可以从firefox的dom查看器里面看到他的childNodes为["\n ", div, "\n"]。

要在firefox下模拟children的属性我们可以这样做:

if (typeof(HTMLElement) != "undefined" && !window.opera) {
HTMLElement.prototype.__defineGetter__("children", function() {
for (var a = [], j = 0, n, i = 0; i < this.childNodes.length; i++) {
n = this.childNodes[i];
if (n.nodeType == 1) {
a[j++] = n;
if (n.name) {
if (!a[n.name])
a[n.name] = [];
a[n.name][a[n.name].length] = n;
}
if (n.id)
a[n.id] = n;
}
}
return a;
});
}

2. firefox和ie的事件

window.event只能在IE下使用,而不能用在Firefox下,这是因为Firefox的event只能在事件发生的现场使用。 Firefox必须从源处加入event作参数传递。IE忽略该参数,用window.event来读取该event。

比方说下面这个在ie下获得鼠标位置的方法:

<button onclick="onClick()" >获得鼠标点击横坐标</button>
<script type="text/javascript">
function onclick(){
alert(event.clientX);
}
</script>

需要改成

<button onclick="onClick(event)">获得OuterHTML</button>
<script type="text/javascript">
function onclick(event){
event = event || window.event;
alert(event.clientX);
}
</script>

才能在两种浏览器下使用

3.HTML对象获取问题

FireFox获取方式document.getElementById("idName")

ie使用document.idname或者document.getElementById("idName")

解决办法:统一使用document.getElementById("idName");

4. const问题

在Firefox下,可以使用const关键字或var关键字来定义常量;

IE下,只能使用var关键字来定义常量;

解决方法:统一使用var关键字来定义常量。

5.frame问题

以下面的frame为例:

<frame src="xxx.html" id="frameId" name="frameName" />

a)访问frame对象

IE:使用window.frameId或者window.frameName来访问这个frame对象,frameId和frameName可以同名;

Firefox:只能使用window.frameName来访问这个frame对象;

另外,在IE和Firefox中都可以使用window.document.getElementById("frameId")来访问这个frame对象;

b) 切换frame内容

在 IE和Firefox中都可以使用

window.document.getElementById("testFrame").src = "xxx.html"或window.frameName.location = "xxx.html"

来切换frame的内容;

如果需要将frame中的参数传回父窗口(注意不是opener,而是parent),可以在frame中使用parent来访问父窗口。例如:

parent.document.form1.filename.value="Aqing";

6. body问题

Firefox的body在body标签没有被浏览器完全读入之前就存在;而IE的body则必须在body标签被浏览器完全读入之后才存在;

7. firefox与IE的父元素(parentElement)的区别

IE:obj.parentElement

firefox:obj.parentNode

解决方法:因为firefox与IE都支持DOM,因此全部使用obj.parentNode

8.innerText的问题

innerText在IE中能正常工作,但是innerText在FireFox中却不行,需用textContent;

解决方法:

if (navigator.appName.indexOf("Explorer") > -1) {
document.getElementById('element').innerText = "my text";
} else {
document.getElementById('element').textContent = "my text";
}

9.AJAX获取XMLHTTP的区别

var xmlhttp;
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} elseif (window.ActiveXObject) { // IE的获取方式
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}

注意:在IE中,xmlhttp.send(content)方法的content可以为空,而firefox则不能为null,应该用send(""),否则会出现411错误。

关于本文给大家介绍的JavaScript 浏览器兼容性总结及常用浏览器兼容性分析,小编就给大家介绍到这里,希望对大家有所帮助!

Javascript 相关文章推荐
fancybox modal的完美解决(右上的X)
Oct 30 Javascript
找出字符串中出现次数最多的字母和出现次数精简版
Nov 07 Javascript
解析Javascript中大括号“{}”的多义性
Dec 02 Javascript
关于js内存泄露的一个好例子
Dec 09 Javascript
javascript将相对路径转绝对路径示例
Mar 14 Javascript
Web前端新人笔记之jquery入门心得(新手必看)
May 17 Javascript
Angular.js中angular-ui-router的简单实践
Jul 18 Javascript
微信小程序slider组件使用详解
Jan 31 Javascript
webpack+vue-cil中proxyTable处理跨域的方法
Jul 20 Javascript
NestJs 静态目录配置详解
Mar 12 Javascript
layer.open提交子页面的form和layedit文本编辑内容的方法
Sep 27 Javascript
js实现全选和全不选功能
Jul 28 Javascript
JavaScript 不支持 indexof 该如何解决
Mar 30 #Javascript
React.js入门学习第一篇
Mar 30 #Javascript
Node.js操作mysql数据库增删改查
Mar 30 #Javascript
基于React.js实现原生js拖拽效果引发的思考
Mar 30 #Javascript
基于jQuery实现Ajax验证用户名是否存在实例
Mar 30 #Javascript
jQuery表格插件datatables用法汇总
Mar 29 #Javascript
基于javascript实现tab切换特效
Mar 29 #Javascript
You might like
PHP中文URL编解码(urlencode()rawurlencode()
2010/07/03 PHP
php中二维数组排序问题方法详解
2015/08/28 PHP
a标签的css样式四个状态
2021/03/09 HTML / CSS
JavaScript效率调优经验
2009/06/04 Javascript
JQuery live函数
2010/12/24 Javascript
自己动手制作jquery插件之自动添加删除行的实现
2011/10/13 Javascript
jQuery插件zoom实现图片全屏放大弹出层特效
2015/04/15 Javascript
JavaScript动态提示输入框输入字数的方法
2015/07/27 Javascript
Javascript实现可旋转的圆圈实例代码
2015/08/04 Javascript
如何动态加载外部Javascript文件
2015/12/02 Javascript
关于cookie的初识和运用(js和jq)
2016/04/07 Javascript
正则表达式(语法篇推荐)
2016/06/24 Javascript
javascript正则表达式中分组详解
2016/07/17 Javascript
JS两种类型的表单提交方法实例分析
2016/11/28 Javascript
使用vue.js实现联动效果的示例代码
2017/01/10 Javascript
Node.js websocket使用socket.io库实现实时聊天室
2017/02/20 Javascript
webpack之引入图片的实现及问题
2018/10/08 Javascript
js实现按钮开关单机下拉菜单效果
2018/11/22 Javascript
Vue js 的生命周期(看了就懂)(推荐)
2019/03/29 Javascript
浅谈vuex为什么不建议在action中修改state
2020/02/02 Javascript
[01:20]辉夜杯背景故事宣传片《辉夜传说》
2015/12/25 DOTA
Python装饰器入门学习教程(九步学习)
2016/01/28 Python
django富文本编辑器的实现示例
2019/04/10 Python
Python加密模块的hashlib,hmac模块使用解析
2020/01/02 Python
python圣诞树编写实例详解
2020/02/13 Python
浅谈keras使用预训练模型vgg16分类,损失和准确度不变
2020/07/02 Python
python+pygame实现坦克大战小游戏的示例代码(可以自定义子弹速度)
2020/08/11 Python
英国电动工具购买网站:Anglia Tool Centre
2017/04/25 全球购物
意大利时尚奢侈品店:D’Aniello Boutique
2021/01/19 全球购物
法律工作求职自荐信
2013/10/31 职场文书
会计职业生涯规划书
2014/01/13 职场文书
2014年幼儿园重阳节活动方案
2014/09/16 职场文书
教育实习指导教师评语
2014/12/31 职场文书
学生上课迟到检讨书
2015/01/01 职场文书
孕妇病假条怎么写
2015/08/17 职场文书
golang 实现对Map进行键值自定义排序
2021/04/28 Golang