首页 web前端 js教程 javascript 浏览器兼容性总结

javascript 浏览器兼容性总结

Jun 01, 2016 am 09:54 AM
javascript 兼容性 浏览器

1. children与childNodes

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

<code class="html"><div id="dd">
<div>yizhu2000</div>
</div></code>
登录后复制

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

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

<code class="javascript">if (typeof(HTMLElement) != "undefined" && !window.opera) {
  HTMLElement.prototype.__defineGetter__("children", function() {
    for (var a = [], j = 0, n, i = 0; i </code>
登录后复制

 

2. firefox和ie的事件

 

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

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

<code class="html"><button onclick="onClick()">获得鼠标点击横坐标</button>
<script type="text/javascript">
function onclick(){
alert(event.clientX);
}
</script> </code>
登录后复制

需要改成

<code class="html"><button onclick="onClick(event)">获得OuterHTML</button>
<script type="text/javascript">
function onclick(event){
event = event || window.event;
alert(event.clientX);
}
</script></code>
登录后复制

才能在两种浏览器下使用

 

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为例:

<code class="html"><frame src="xxx.html" id="frameId" name="frameName"></code>
登录后复制

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中都可以使用

<code class="javascript">window.document.getElementById("testFrame").src = "xxx.html"或window.frameName.location = "xxx.html"</code>
登录后复制

来切换frame的内容;

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

<code class="javascript">parent.document.form1.filename.value="Aqing";</code>
登录后复制

 

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;

解决方法:

<code class="javascript">if (navigator.appName.indexOf("Explorer") > -1) {
  document.getElementById('element').innerText = "my text";
} else {
  document.getElementById('element').textContent = "my text";
} </code>
登录后复制

 

9.AJAX获取XMLHTTP的区别

<code class="javascript">var xmlhttp;
if (window.XMLHttpRequest) {
  xmlhttp = new XMLHttpRequest();
} elseif (window.ActiveXObject) { // IE的获取方式
  xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}</code>
登录后复制

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

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
<🎜>掩盖:探险33-如何获得完美的色度催化剂
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1677
14
CakePHP 教程
1430
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
币安广场怎么样可靠吗 币安广场怎么样可靠吗 May 07, 2025 pm 07:18 PM

币安广场(Binance Square)是币安交易所提供的一个社交媒体平台,旨在为用户提供一个交流和分享加密货币相关信息的空间。本文将详细探讨币安广场的功能、可靠性以及用户体验,帮助你更好地了解这个平台。

2025币安Binance交易所最新登录入口 2025币安Binance交易所最新登录入口 May 07, 2025 pm 07:03 PM

币安(Binance)作为全球领先的加密货币交易所,始终致力于为用户提供安全、便捷的交易体验。随着时间的推移,币安不断优化其平台功能和用户界面,以满足用户不断变化的需求。2025年,币安推出了新的登录入口,旨在进一步提升用户体验。

ok交易所国内如何注册?ok交易平台大陆新手注册使用指南 ok交易所国内如何注册?ok交易平台大陆新手注册使用指南 May 08, 2025 pm 10:51 PM

在加密货币市场中,选择一个可靠的交易平台是至关重要的。OK交易平台作为全球知名的数字资产交易所,吸引了大量大陆新手用户。本指南将详细介绍如何在OK交易平台上进行注册和使用,帮助新手用户快速上手。

2025最安全交易所TOP5:黑U避坑指南,资金100%保命法则 2025最安全交易所TOP5:黑U避坑指南,资金100%保命法则 May 08, 2025 pm 08:27 PM

在加密货币交易领域,交易所的安全性始终是用户关注的重点。2025年,经过多年的发展和演变,一些交易所凭借其卓越的安全措施和用户体验脱颖而出。本文将详细介绍2025年最安全的五大交易所,并提供如何避开黑U(黑客攻击用户)的实用指南,确保您的资金100%安全。

2025币安交易所最新入口地址 2025币安交易所最新入口地址 May 07, 2025 pm 07:00 PM

币安(Binance)作为全球领先的加密货币交易所,始终致力于为用户提供安全、便捷的交易体验。随着时间的推移,币安不断优化其平台功能和用户界面,以满足用户不断变化的需求。2025年,币安推出了新的登录入口,旨在进一步提升用户体验。

2025币安在线网页地址 2025币安在线网页地址 May 07, 2025 pm 06:54 PM

币安(Binance)作为全球领先的加密货币交易所,始终致力于为用户提供安全、便捷的交易体验。随着时间的推移,币安不断优化其平台功能和用户界面,以满足用户不断变化的需求。2025年,币安推出了新的登录入口,旨在进一步提升用户体验。

币安Binance交易所安装、注册详细指南(2025最新步骤) 币安Binance交易所安装、注册详细指南(2025最新步骤) May 08, 2025 pm 11:06 PM

币安(Binance)是全球领先的加密货币交易平台之一,提供多种数字资产的交易服务。如果你正在考虑使用币安进行加密货币交易,本文将为你提供详细的安装和注册指南。

欧易ios官方网站入口 okx欧易官方网站苹果手机注册入口 欧易ios官方网站入口 okx欧易官方网站苹果手机注册入口 May 08, 2025 pm 11:09 PM

如果你是一位苹果手机用户,并且对加密货币交易感兴趣,那么你一定不能错过OKX欧易这个平台。OKX欧易作为全球领先的加密货币交易所之一,提供了多种数字资产的交易服务,涵盖了比特币、以太坊、莱特币等主流币种,同时还支持多种山寨币和新兴代币的交易。无论你是刚入门的投资者,还是经验丰富的交易者,OKX欧易都能够满足你的需求。下面我们将详细介绍如何通过苹果手机在OKX欧易官方网站上进行注

See all articles