`

firefox和IE浏览器兼容问题(总结)

阅读更多

1.集合类对象问题
说明:IE下,可以使用()或[]获取集合类对象;
Firefox下,只能使用[]获取集合类对象.  
解决方法:统一使用[]获取集合类对象.

2.HTML对象获取问题
FireFox:document.getElementById("idName");
ie:document.idname或者document.getElementById("idName").
解决办法:统一使用document.getElementById("idName");

3.const问题
说明:Firefox下,可以使用const关键字或var关键字来定义常量;
IE下,只能使用var关键字来定义常量.  
解决方法:统一使用var关键字来定义常量.

4.window.event问题
说明:window.event只能在IE下运行,而不能在Firefox下运行,这是因为Firefox的event只能在事件发生的现场使用.   Firefox必须从源处加入event作参数传递。Ie忽略该参数,用window.event来读取该event。
解决方法:  
IE&Firefox:  
Submitted(event)"/>   …
<script   language="javascript">  
function   Submitted(evt)   {  
evt=evt?evt:(window.event?window.event:null);
}  
</script>
5.event.x与event.y问题
说明:IE下,even对象有x,y属性,但是没有pageX,pageY属性;
Firefox下,even对象有pageX,pageY属性,但是没有x,y属性.  
解决方法:使用mX(mX   =   event.x   ?   event.x   :   event.pageX;)来代替IE下的event.x或者Firefox下的event.pageX.
  
6.event.srcElement问题
说明:IE下,event对象有srcElement属性,但是没有target属性;
Firefox下,even对象有target属性,但是没有srcElement属性.  
解决方法:使用obj(obj   =   event.srcElement   ?   event.srcElement   :   event.target;)来代替IE下的event.srcElement或者Firefox下的event.target.     请同时注意event的兼容性问题。
 
7.window.location.href问题
说明:IE或者Firefox2.0.x下,可以使用window.location或window.location.href;
Firefox1.5.x下,只能使用window.location.  
解决方法:使用window.location来代替window.location.href.  
 
8.模态和非模态窗口问题
说明:IE下,可以通过showModalDialog和showModelessDialog打开模态和非模态窗口;Firefox下则不能.  
解决方法:直接使用window.open(pageURL,name,parameters)方式打开新窗口。
如果需要将子窗口中的参数传递回父窗口,可以在子窗口中使用window.opener来访问父窗口.  
例如:var   parWin   =   window.opener;   parWin.document.getElementById("Aqing").value   =   "Aqing";  
 
9.frame问题
以下面的frame为例:
<frame   src="xxx.html"   id="frameId"   name="frameName"   />

(1)访问frame对象:
IE:使用window.frameId或者window.frameName来访问这个frame对象.   frameId和frameName可以同名。
Firefox:只能使用window.frameName来访问这个frame对象.
另外,在IE和Firefox中都可以使用window.document.getElementById("frameId")来访问这个frame对象.

(2)切换frame内容:
在IE和Firefox中都可以使用window.document.getElementById("testFrame").src   =   "xxx.html"或window.frameName.location   =   "xxx.html"来切换frame的内容.
如果需要将frame中的参数传回父窗口(注意不是opener,而是parent   frame),可以在frme中使用parent来访问父窗口。例如:parent.document.form1.filename.value="Aqing";
 
10.body问题
Firefox的body在body标签没有被浏览器完全读入之前就存在;而IE的body则必须在body标签被浏览器完全读入之后才存在.  
 
11.   事件委托方法
IE:document.body.onload   =   inject;   //Function   inject()在这之前已被实现
Firefox:document.body.onload   =   inject();
  
 
12.   firefox与IE的父元素(parentElement)的区别
IE:obj.parentElement
firefox:obj.parentNode
解决方法:   因为firefox与IE都支持DOM,因此使用obj.parentNode是不错选择.

 
13.cursor:hand   VS   cursor:pointer  
firefox不支持hand,但ie支持pointer
解决方法:   统一使用pointer

 
14.innerText在IE中能正常工作,但是innerText在FireFox中却不行.   需用textContent。
解决方法:
if(navigator.appName.indexOf("Explorer")   >   -1){
        document.getElementById('element').innerText   =   "my   text";
}   else{
        document.getElementById('element').textContent   =   "my   text";
}
 
15.   FireFox中设置HTML标签的style时,所有位置性和字体尺寸的值必须后跟px。这个ie也是支持的。
 
16.   ie,firefox以及其它浏览器对于   table   标签的操作都各不相同,
在ie中不允许对table和tr的innerHTML赋值,使用js增加一个tr时,使用appendChild方法也不管用。
解决方法:
//向table追加一个空行:
var   row   =   otable.insertRow(-1);
var   cell   =   document.createElement("td");
cell.innerHTML   =   "   ";  
cell.className   =   "XXXX";  
row.appendChild(cell);
 
17.   padding   问题
padding   5px   4px   3px   1px   FireFox无法解释简写,
必须改成   padding-top:5px;   padding-right:4px;   padding-bottom:3px;   padding-left:1px;
 
18.   消除ul、ol等列表的缩进时
样式应写成:list-style:none;margin:0px;padding:0px;
其中margin属性对IE有效,padding属性对FireFox有效

 
19.   CSS透明
IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。  
FF:opacity:0.6。  
 
20.   CSS圆角
IE:不支持圆角。  
FF:   -moz-border-radius:4px,或者-moz-border-radius-topleft:4px;-moz-border-   radius-topright:4px;-moz-border-radius-bottomleft:4px;-moz-border-radius-   bottomright:4px;。

 
21.   CSS双线凹凸边框
IE:border:2px   outset;。  
FF:   -moz-border-top-colors:   #d4d0c8   white;-moz-border-left-colors:   #d4d0c8   white;-moz-border-right-colors:#404040   #808080;-moz-border-bottom-colors:#404040   #808080;

 
22.   对select的options集合操作
枚举元素除了[]外,SelectName.options.item()也是可以的,   另外SelectName.options.length,   SelectName.options.add/remove都可以在两种浏览器上使用。注意在add后赋值元素,否则会失败(本人试验如此)。
 
23.   XMLHTTP的区别
//mf
if   (window.XMLHttpRequest)   //mf
    {
    xmlhttp=new   XMLHttpRequest()
    xmlhttp.onreadystatechange=xmlhttpChange
    xmlhttp.open("GET",url,true)
    xmlhttp.send(null)
    }
//ie
else   if   (window.ActiveXObject)     //   code   for   IE
    {
    xmlhttp=new   ActiveXObject("Microsoft.XMLHTTP")
        if   (xmlhttp)
        {
        xmlhttp.onreadystatechange=xmlhttpChange
        xmlhttp.open("GET",url,true)
        xmlhttp.send()
        }
    }
}
24.css中的width和padding
在IE7和FF中width宽度不包括padding,在Ie6中包括padding.


[转自:http://blog.csdn.net/lfzwenzhu/archive/2008/01/31/2075096.aspx]

分享到:
评论

相关推荐

    火狐与IE浏览器兼容代码

    ### 火狐与IE浏览器兼容代码:innerText与innerHTML的应用及转换 在Web开发中,兼容性问题一直是开发者关注的重点之一。特别是在早期的浏览器版本中,不同浏览器对某些特性的支持差异导致了开发者不得不采取一些...

    在Firefox下直接调用IE浏览器(IETab这个插件).zip

    标签中再次强调了这个插件的功能,即在Firefox中调用IE浏览器。这表明这个插件是解决跨浏览器兼容性问题的一个解决方案,尤其是在企业环境中,可能有一些内部系统或遗留应用只能在IE下正常工作。 总的来说,IETab是...

    javascript在firefox与ie下的兼容性总结

    JavaScript在Firefox和IE之间的兼容性问题一直是前端开发者面临的一大挑战。由于这两个浏览器内核的不同,导致在处理某些JavaScript特性时存在差异。以下是一些常见的兼容性问题及其解决方案: 1. **Document.form....

    IE浏览器和火狐浏览器兼容问题有部分js

    标题和描述均提到了“IE浏览器和火狐浏览器兼容问题有部分js”,这指向了在Web开发中一个常见的挑战——确保网页在不同浏览器上的表现一致。浏览器兼容性问题主要源于不同浏览器对Web标准(如HTML、CSS和JavaScript...

    IE浏览器和火狐浏览器兼容问题.doc

    标题提及的“IE浏览器和火狐浏览器兼容问题”主要集中在CSS样式方面,因为CSS在不同浏览器之间的解析方式有所差异,导致在Internet Explorer(IE)和Firefox中显示效果可能不一致。以下是一些关键的兼容性问题及解决...

    ie和火狐浏览器兼容问题

    在网页开发过程中,浏览器兼容性问题常常困扰着开发者,尤其是IE和Firefox之间的差异。以下是一些针对CSS在IE和Firefox浏览器中的兼容性问题及其解决策略: 1. **DOCTYPE影响CSS处理**:不同的DOCTYPE声明会影响...

    判断火狐(firefox)或ie浏览器

    ### 知识点详解:判断火狐(Firefox)或IE浏览器 在Web开发领域,浏览器兼容性一直是开发者面临的重要问题之一。不同的浏览器对Web标准的支持程度不同,这可能导致同样的网页在不同浏览器中的显示效果存在差异。为了...

    Firefox火狐浏览器官方52.0.1-win32版本exe安装包

    总结,Firefox火狐浏览器52.0.1-win32版本凭借其强大的功能、出色的性能和对用户隐私的重视,成为了众多网民的首选浏览器。正确安装并充分利用其各项功能,能够显著提升网络浏览体验。无论是日常冲浪还是工作学习,...

    Selenium+谷歌/火狐/IE浏览器+driver下载

    本压缩包“Selenium+谷歌/火狐/IE浏览器+driver下载”提供了与Selenium3.14版本兼容的最新浏览器驱动,包括`chromedriver`、`geckodriver`和`IEDriverServer`。 首先,我们要了解Selenium的核心组件——WebDriver。...

    FireFox火狐浏览器与IE兼容问题 - 透明滤镜 DIV滚动条

    下面是关于FireFox火狐浏览器与IE浏览器兼容问题的总结: 一、cursor指针问题 在IE浏览器中,cursor:pointer可以实现手形指针的效果,但是在FireFox火狐浏览器中,cursor:hand是无效的,需要使用cursor:pointer来...

    Firefox和IE兼容参考

    在网页开发过程中,Firefox(火狐浏览器)和Internet Explorer(IE浏览器)的兼容性问题一直是一大挑战。这两个浏览器在解析HTML、CSS以及JavaScript时有着不同的实现方式,导致某些代码在Firefox下正常运行,但在IE...

    Selenium各大浏览器驱动【谷歌chrme、火狐Firefox、IE浏览器】

    3. **IE浏览器驱动**: Internet Explorer的驱动是`IEDriverServer`。下载地址为:http://selenium-release.storage.googleapis.com/index.html。注意,IE驱动需要特定的配置,比如启用“兼容性视图设置”和“增强...

    让IE和火狐同时兼容

    特别是在早期的Web时代,Internet Explorer(简称IE)与Mozilla Firefox(简称火狐)这两款浏览器之间存在着显著的差异,这使得页面设计师不得不花费大量时间去解决它们之间的兼容性问题。本文将详细介绍如何使网站...

    ie和火狐的兼容问题总结

    ### IE和火狐的兼容问题总结 在前端开发过程中,我们经常会遇到不同浏览器之间的兼容性问题,特别是Internet Explorer(简称IE)与Firefox(火狐)之间的差异。由于这两种浏览器在处理CSS和JavaScript方面存在显著...

    Firefox与IE浏览器的javascript兼容性问题

    JavaScript 是一种广泛应用于网页开发的脚本语言,它在不同的浏览器上可能存在兼容性问题,特别是老版本的 Internet Explorer (IE) 和 Mozilla Firefox (MF)。本文将深入探讨这两个浏览器之间的 JavaScript 兼容性...

    wdatePicker 解决火狐和IE兼容

    标题“wdatePicker 解决火狐和IE兼容”指出,这是一个关于JavaScript日期选择插件wdatePicker的讨论,特别是针对其在不同浏览器,尤其是火狐(Firefox)和Internet Explorer(IE)之间的兼容性问题。wdatePicker是一...

    CSS中火狐浏览器与IE浏览器的兼容

    ### CSS中火狐浏览器与IE浏览器的兼容 在前端开发领域,确保网页在不同浏览器间的兼容性至关重要。本文旨在提供一些实用的技巧和方法来帮助开发者解决CSS在Internet Explorer(IE)与Mozilla Firefox(火狐)这两款...

    Firefox和IE兼容性问题及解决方法总结

    在开发跨浏览器的应用时,尤其是基于JavaScript的网页应用,Firefox和Internet Explorer(IE)之间的兼容性问题时常出现,这给开发者带来不小的困扰。本文将针对这些常见问题提供解决方案。 1. **outerHTML属性兼容...

Global site tag (gtag.js) - Google Analytics