iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JS在IE和Firefox兼容性问题及解决方法是怎样的
  • 189
分享到

JS在IE和Firefox兼容性问题及解决方法是怎样的

2024-04-02 19:04:59 189人浏览 八月长安
摘要

js在IE和Firefox兼容性问题及解决方法是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。你对JS在IE和Firef

js在IE和Firefox兼容性问题及解决方法是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

你对JS在IE和Firefox兼容性问题解决方法是否熟悉,这里和大家分享一下,比如现有代码中存在许多document.fORMName.item("itemName")这样的语句,不能在MF下运行。我们可以改用document.formName.elements["elementName"]来解决。

JS在IE和Firefox兼容性问题汇编

以下以IE代替InternetExplorer,以MF代替MozzilaFirefox

1.document.form.item问题

(1)现有问题:

现有代码中存在许多document.formName.item("itemName")这样的语句,不能在MF下运行

(2)解决方法:

改用document.formName.elements["elementName"]

(3)其它

2.集合类对象问题

(1)现有问题:

现有代码中许多集合类对象取用时使用(),IE能接受,MF不能。

(2)解决方法:

改用[]作为下标运算。如:document.forms("formName")改为document.forms["formName"]。
又如:document.getElementsByName("inputName")(1)改为document.getElementsByName("inputName")[1]
(3)其它

3.window.event

(1)现有问题:

使用window.event无法在MF上运行

(2)解决方法:

MF的event只能在事件发生的现场使用,此问题暂无法解决。可以这样变通:
原代码(可在IE中运行):

<inputtypeinputtype="button"name="someButton"value="提交" onclick="javascript:GotoSubmit()"/> ...  <scriptlanguagescriptlanguage="javascript"> functiongotoSubmit(){  ...  alert(window.event);//usewindow.event  ...  }  </script>

新代码(可在IE和MF中运行):

<inputtypeinputtype="button"name="someButton"value="提交" onclick="javascript:gotoSubmit(event)"/> ...  <scriptlanguagescriptlanguage="javascript"> functiongotoSubmit(evt){  evtevt=evt?evt:(window.event?window.event:null);  ...  alert(evt);//useevt  ...  }  </script>

此外,如果新代码中***行不改,与老代码一样的话(即gotoSubmit调用没有给参数),则仍然只能在IE中运行,但不会出错。所以,这种方案tpl部分仍与老代码兼容。

4.HTML对象的id作为对象名的问题

(1)现有问题

在IE中,html对象的ID可以作为document的下属对象变量名直接使用。在MF中不能。

(2)解决方法

用getElementById("idName")代替idName作为对象变量使用。

5.用idName字符串取得对象的问题

(1)现有问题

在IE中,利用eval(idName)可以取得id为idName的HTML对象,在MF中不能。

(2)解决方法

用getElementById(idName)代替eval(idName)。

6.变量名与某HTML对象id相同的问题

(1)现有问题

在MF中,因为对象id不作为HTML对象的名称,所以可以使用与HTML对象id相同的变量名,IE中不能。

(2)解决方法

在声明变量时,一律加上var,以避免歧义,这样在IE中亦可正常运行。
此外,***不要取与HTML对象id相同的变量名,以减少错误。

(3)其它

7.event.x与event.y问题

(1)现有问题

在IE中,event对象有x,y属性,MF中没有。

(2)解决方法

在MF中,与event.x等效的是event.pageX。但event.pageXIE中没有。
故采用event.clientX代替event.x。在IE中也有这个变量。
event.clientX与event.pageX有微妙的差别(当整个页面有滚动条的时候),不过大多数时候是等效的。

如果要完全一样,可以稍麻烦些:mX=event.x?event.x:event.pageX;然后用mX代替event.x

(3)其它
event.layerX在IE与MF中都有,具体意义有无差别尚未试验。

8.关于frame

(1)现有问题

在IE中可以用window.testFrame取得该frame,mf中不行

(2)解决方法

在frame的使用方面mf和ie的最主要的区别是:

如果在frame标签中书写了以下属性:

<framesrcframesrc="xx.htm"id="frameId"name="frameName"/>

那么ie可以通过id或者name访问这个frame对应的window对象,而mf只可以通过name来访问这个frame对应的window对象。例如如果上述frame标签写在最上层的window里面的htm里面,那么可以这样访问

ie:window.top.frameId或者window.top.frameName来访问这个window对象
mf:只能这样window.top.frameName来访问这个window对象

另外,在mf和ie中都可以使用window.top.document.getElementById("frameId")来访问frame标签,并且可以通过window.top.document.getElementById("testFrame").src='xx.htm'来切换frame的内容,也都可以通过window.top.frameName.location='xx.htm'来切换frame的内容

9.在mf中,自己定义的属性必须getAttribute()取得

10.在mf中没有parentElementparement.children而用

parentnodeparentNode.childNodes
childNodes的下标的含义在IE和MF中不同,MF使用DOM规范,childNodes中会插入空白文本节点。
一般可以通过node.getElementsByTagName()来回避这个问题。
当html中节点缺失时,IE和MF对parentNode的解释不同,例如

<form> <table> <input/> </table> </form>

MF中input.parentNode的值为form,而IE中input.parentNode的值为空节点

MF中节点没有removeNode方法,必须使用如下方法node.parentNode.removeChild(node)

11.const问题

(1)现有问题:

在IE中不能使用const关键字。如constconstVar=32;在IE中这是语法错误。

(2)解决方法:

不使用const,以var代替。

12.body对象

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

13.urlencoding

在js中如果书写url就直接写&不要写&amp;例如varurl='xx.jsp?objectName=xx&amp;objectEvent=xxx';
frm.action=url那么很有可能url不会被正常显示以至于参数没有正确的传到服务器
一般会服务器报错参数没有找到
当然如果是在tpl中例外,因为tpl中符合xml规范,要求&书写为&amp;
一般MF无法识别js中的&amp;

14.nodeName和tagName问题

(1)现有问题:

在MF中,所有节点均有nodeName值,但textNode没有tagName值。在IE中,nodeName的使用好象有问题。

(2)解决方法:

使用tagName,但应检测其是否为空。

15.元素属性

IE下input.type属性为只读,但是MF下可以修改

16.document.getElementsByName()和document.all[name]的问题

(1)现有问题:

在IE中,getElementsByName()、document.all[name]均不能用来取得div元素(是否还有其它不能取的元素还不知道)。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网JavaScript频道,感谢您对编程网的支持。

--结束END--

本文标题: JS在IE和Firefox兼容性问题及解决方法是怎样的

本文链接: https://www.lsjlt.com/news/86557.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JS在IE和Firefox兼容性问题及解决方法是怎样的
    JS在IE和Firefox兼容性问题及解决方法是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。你对JS在IE和Firef...
    99+
    2024-04-02
  • IE7.JS怎样解决IE兼容性问题
    这篇文章给大家介绍 IE7.JS怎样解决IE兼容性问题,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。和大家重点讨论一下如何使用IE7.JS解决IE兼容性问题,IE7.JS是一个用来使老...
    99+
    2024-04-02
  • Javascript的IE和Firefox有哪些兼容性问题
    这篇文章主要介绍“Javascript的IE和Firefox有哪些兼容性问题”,在日常操作中,相信很多人在Javascript的IE和Firefox有哪些兼容性问题问题上存在疑惑,小编查阅了各式资料,整理出...
    99+
    2024-04-02
  • IE7.JS如何解决IE兼容性问题
    小编给大家分享一下IE7.JS如何解决IE兼容性问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!IE7.JS解决IE兼容性问题...
    99+
    2024-04-02
  • 怎么解决DIV+CSS布局在IE和firefox中不兼容的问题
    本篇内容介绍了“怎么解决DIV+CSS布局在IE和firefox中不兼容的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅...
    99+
    2024-04-02
  • 如何使用important解决firefox和ie的css兼容问题
    这篇文章主要讲解了“如何使用important解决firefox和ie的css兼容问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用importan...
    99+
    2024-04-02
  • IE和Firefox中Javascript兼容性问题的示例分析
    这篇文章主要介绍了IE和Firefox中Javascript兼容性问题的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。由于长久以来J...
    99+
    2024-04-02
  • JS脚本兼容性问题的解决方法
    这篇文章给大家介绍JS脚本兼容性问题的解决方法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。这里和大家分享一下解决JS脚本兼容的几个小技巧,关于JS脚本兼...
    99+
    2024-04-02
  • 如何探究IE和Firefox在JavaScript方面的兼容性
    这期内容当中小编将会给大家带来有关如何探究IE和Firefox在JavaScript方面的兼容性,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。IE和Firefox在Jav...
    99+
    2024-04-02
  • 如何解决JS在firefox和IE下差异问题
    这篇文章主要介绍了如何解决JS在firefox和IE下差异问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JS在firefox和IE下差异...
    99+
    2024-04-02
  • 如何解决axios在ie下的兼容性问题
    小编给大家分享一下如何解决axios在ie下的兼容性问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!首先说下axios虽说是支...
    99+
    2024-04-02
  • IE、Firefox等浏览器不兼容原因及解决方法是什么
    这篇文章给大家介绍IE、Firefox等浏览器不兼容原因及解决方法是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。你对,IE、Firefox等浏览器不兼容原因及解决方法是否了解,这...
    99+
    2024-04-02
  • 如何调用IE7 JS Library库解决IE兼容性问题
    这篇文章给大家介绍如何调用IE7 JS Library库解决IE兼容性问题,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。和大家重点讨论一下IE7 JS Library库解决IE兼容性问...
    99+
    2024-04-02
  • 如何解决原生js方法document.getElementsByClassName在ie8及其以下的兼容性问题
    这篇文章将为大家详细讲解有关如何解决原生js方法document.getElementsByClassName在ie8及其以下的兼容性问题,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文...
    99+
    2024-04-02
  • 一行代码怎样解决各种IE兼容问题
    一行代码怎样解决各种IE兼容问题,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。百度源代码如下代码如下:<!Doctype html>...
    99+
    2024-04-02
  • JS如何解决position:sticky的兼容性问题
    这篇文章主要介绍JS如何解决position:sticky的兼容性问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在项目中有用到sticky的布局,可是由于兼容性问题,在安卓端没有...
    99+
    2024-04-02
  • 解决IE6、IE7、IE8、Firefox兼容的几种方案分别是怎样的
    本篇文章给大家分享的是有关解决IE6、IE7、IE8、Firefox兼容的几种方案分别是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。解...
    99+
    2024-04-02
  • IE8兼容性问题的快速解决方法是什么
    IE8兼容性问题的快速解决方法是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。为了实现IE8兼容基于其它网页标准开发的网站,IE8还专门提...
    99+
    2024-04-02
  • vue-cli3项目在IE浏览器打开兼容问题及解决
    目录vue-cli3在IE浏览器打开兼容问题问题描述方案vue-cli 在IE下兼容设置解决办法如下vue-cli3在IE浏览器打开兼容问题 问题描述 vue打包的项目在ie浏览器上...
    99+
    2024-04-02
  • 怎么解决IE7和IE8兼容性问题
    怎么解决IE7和IE8兼容性问题,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。IE8会是福音还是又一个光环据称全面兼容标准,今天向大家介绍如何...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作