zl程序教程

您现在的位置是:首页 >  前端

当前栏目

【总结】IE和Firefox的Javascript兼容性总结

JavaScript 总结 IE firefox 兼容性
2023-09-27 14:25:13 时间
1.firefox不能对innerText支持。


firefox支持innerHTML但却不支持innerText。它支持textContent来实现innerText。只是默认把多余的空格也保留了。

假设不用textContent,假设字符串里面不包括HTML代码也能够用innerHTML取代。


2.禁止选取网页内容:
在IE中一般用js:obj.onselectstart=function(){return false;}
而firefox用CSS:-moz-user-select:none
3.滤镜的支持(例:透明滤镜):
IE:filter:alpha(opacity=10);
firefox:-moz-opacity:.10;
4.捕获事件:
IE:obj.setCapture() 、obj.releaseCapture()
Firefox: document.addEventListener("mousemove",mousemovefunction,true);
document.removeEventListener("mousemove",mousemovefunction,true);
5.获取鼠标位置:
IE:event.clientX、event.clientY
firefox:须要事件函数传递事件对象
obj.onmousemove=function(ev){
      X= ev.pageX;Y=ev.pageY;
}
6.DIV等元素的边界问题:
比方:设置一个div的CSS::{width:100px;height:100px;border:#000000 1px solid;}
IE中:div的宽度(包含边框宽度):100px,div的高度(包含边框宽度):100px。
而firefox:div的宽度(包含边框宽度):102px。div的高度(包含边框宽度):102px;
所以在做这个兼容IE和firefox的拖动窗体时,在js和css的写法上要动点脑筋,给大家两个小技巧
一.推断浏览器类型:
var isIE=document.all?

true:false;
我写了一个变量,假设支持document.all语法那么isIE=true。否则isIE=false
二.在不同浏览器下的CSS处理:
一般能够用!important来优先使用css语句(仅firefox支持)
比方:{border-width:0px!important;border-width:1px;}
在firefox下这个元素是没有边框的,在IE下边框宽度是1px
      1.document.formName.item("itemName") 问题
问题说明:IE下。能够使用 document.formName.item("itemName") 或 document.formName.elements ["elementName"];Firefox下,仅仅能使用document.formName.elements["elementName"]。
解决方法:统一使用document.formName.elements["elementName"]。
2.集合类对象问题
问题说明:IE下,能够使用 () 或 [] 获取集合类对象;Firefox下,仅仅能使用 [ ]获取集合类对象。


解决方法:统一使用 [] 获取集合类对象。
3.自己定义属性问题
问题说明:IE下,能够使用获取常规属性的方法来获取自己定义属性,也能够使用 getAttribute() 获取自己定义属性。Firefox下。仅仅能使用 getAttribute() 获取自己定义属性。
解决方法:统一通过 getAttribute() 获取自己定义属性。
4.eval("idName")问题
问题说明:IE下。能够使用 eval("idName") 或 getElementById("idName") 来取得 id 为 idName 的HTML对象。Firefox下,仅仅能使用 getElementById("idName") 来取得 id 为 idName 的HTML对象。
解决方法:统一用 getElementById("idName") 来取得 id 为 idName 的HTML对象。
5.变量名与某HTML对象ID同样的问题
问题说明:IE下,HTML对象的ID能够作为 document 的下属对象变量名直接使用,Firefox下则不能。Firefox下。能够使用与HTML对象ID同样的变量名。IE下则不能。


解决方法:使用 document.getElementById("idName") 取代 document.idName。最好不要取HTML对象ID同样的变量名,以降低错误;在声明变量时,一律加上varkeyword。以避免歧义。


6.const问题
问题说明:Firefox下,能够使用constkeyword或varkeyword来定义常量;IE下,仅仅能使用varkeyword来定义常量。
解决方法:统一使用varkeyword来定义常量。
7.input.type属性问题
问题说明:IE下 input.type 属性为仅仅读;可是Firefox下 input.type 属性为读写。
       解决的方法:不改动 input.type 属性。

假设必需要改动。能够先隐藏原来的input,然后在相同的位置再插入一个新的input元素。
8.window.event问题
问题说明:window.event 仅仅能在IE下执行,而不能在Firefox下执行,这是由于Firefox的event仅仅能在事件发生的现场使用。


解决方法:在事件发生的函数上加上event參数。在函数体内(如果形參为evt)使用 var myEvent = evt?evt:(window.event?

window.event:null)
       演示样例:<input type="button" onclick="doSomething(event)"/>
<script language="javascript">
function doSomething(evt) {
var myEvent = evt?evt:(window.event?

window.event:null)
...
}
       9.event.x与event.y问题
问题说明:IE下,even对象有x、y属性,可是没有pageX、pageY属性;Firefox下,even对象有pageX、pageY属性。可是没有x、y属性。
解决方法:var myX = event.x ? event.x : event.pageX; var myY = event.y ? event.y:event.pageY;
       假设考虑第8条问题,就改用myEvent取代event就可以。


10.event.srcElement问题
问题说明:IE下。even对象有srcElement属性。可是没有target属性。Firefox下,even对象有target属性。可是没有srcElement属性。
解决方法:使用srcObj = event.srcElement ? event.srcElement : event.target;
       假设考虑第8条问题。就改用myEvent取代event就可以。
11.window.location.href问题
问题说明:IE或者Firefox2.0.x下,能够使用window.location或window.location.href。Firefox1.5.x下,仅仅能使用window.location。


解决方法:使用 window.location 来取代 window.location.href。

当然也能够考虑使用 location.replace()方法。


12.模态和非模态窗体问题
问题说明:IE下。能够通过showModalDialog和showModelessDialog打开模态和非模态窗体;Firefox下则不能。
解决方法:直接使用 window.open(pageURL,name,parameters) 方式打开新窗体。
       假设须要将子窗体中的參数传递回父窗体,能够在子窗体中使用window.opener来訪问父窗体。假设须要父窗体控制子窗体的话,使用var subWindow = window.open(pageURL,name,parameters); 来获得新开的窗体对象。
13.frame和iframe问题
以以下的frame为例:
<frame src="xxx.html" id="frameId" name="frameName" />
(1)訪问frame对象
IE:使用window.frameId或者window.frameName来訪问这个frame对象;
Firefox:使用window.frameName来訪问这个frame对象;
       解决方法:统一使用 window.document.getElementById("frameId") 来訪问这个frame对象;
(2)切换frame内容
在IE和Firefox中都能够使用window.document.getElementById("frameId").src = "xxx.html"或window.frameName.location = "xxx.html"来切换frame的内容;
假设须要将frame中的參数传回父窗体,能够在frame中使用parentkeyword来訪问父窗体。
14.body加载问题
问题说明:Firefox的body对象在body标签没有被浏览器全然读入之前就存在;而IE的body对象则必须在body标签被浏览器全然读入之后才存在。


       [注] 这个问题尚未实际验证,待验证后再来改动。
       [注] 经验证,IE6、Opera9以及FireFox2中不存在上述问题,单纯的JS脚本能够訪问在脚本之前已经加载的全部对象和元素,即使这个元素还没有加载完毕。
15. 事件托付方法
问题说明:IE下,使用 document.body.onload = inject; 当中function inject()在这之前已被实现。在Firefox下,使用 document.body.onload = inject();
解决方法:统一使用 document.body. Function('inject()'); 或者 document.body.onload = function(){/* 这里是代码 */}
       [注意] Function和function的差别
16.訪问的父元素的差别
问题说明:在IE下,使用 obj.parentElement 或 obj.parentNode 訪问obj的父结点;在firefox下。使用 obj.parentNode 訪问obj的父结点。
解决方法:由于firefox与IE都支持DOM,因此统一使用obj.parentNode 来訪问obj的父结点。
17.cursor:hand VS cursor:pointer
问题说明:firefox不支持hand。但ie支持pointer ,两者都是手形指示。


解决方法:统一使用pointer。
18.innerText的问题.
       问题说明:innerText在IE中能正常工作,可是innerText在FireFox中却不行。
       解决方法:在非IE浏览器中使用textContent取代innerText。


       演示样例:
if(navigator.appName.indexOf("Explorer") >-1){
document.getElementById('element').innerText = "my text";
} else{
document.getElementById('element').textContent = "my text";
}
       [注] innerHTML 同一时候被ie、firefox等浏览器支持,其它的。如outerHTML等仅仅被ie支持,最好不用。


19. 对象宽高赋值问题
  问题说明:FireFox中类似 obj.style.height = imgObj.height 的语句无效。
       解决方法:统一使用 obj.style.height = imgObj.height + 'px';
20. Table操作问题
       问题说明: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);
       [注] 因为俺非常少使用JS直接操作表格,这个问题没有遇见过。建议使用JS框架集来操作table,如JQuery。
21. ul和ol列表缩进问题
  消除ul、ol等列表的缩进时。样式应写成:list-style:none;margin:0px;padding:0px;
当中margin属性对IE有效,padding属性对FireFox有效。← 此句表述有误,具体见↓
       [注] 这个问题尚未实际验证。待验证后再来改动。
       [注] 经验证。在IE中,设置margin:0px能够去除列表的上下左右缩进、空白以及列表编号或圆点,设置padding对样式没有影响。在Firefox 中。设置margin:0px只能够去除上下的空白,设置padding:0px后只能够去掉左右缩进,还必须设置list-style:none才 能去除列表编号或圆点。也就是说,在IE中只设置margin:0px就可以达到终于效果。而在Firefox中必须同一时候设置margin:0px、 padding:0px以及list-style:none三项才干达到终于效果。
22. CSS透明问题
IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。


FF:opacity:0.6。
       [注] 最好两个都写。并将opacity属性放在以下。


23. CSS圆角问题
IE:ie7下面版本号不支持圆角。
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;。
       [注] 圆角问题是CSS中的经典问题,建议使用JQuery框架集来设置圆角,让这些复杂的问题留给别人去想吧。
关于CSS中的问题实在太多了,甚至相同的CSS定义在不同的页面标准中的显示效果都是不一样的。一个合乎发展的建议是,页面採用标准DHTML标准 编写。较少使用table,CSS定义尽量按照标准DOM。同一时候兼顾IE、Firefox、Opera等主流浏览器。BTW,非常多情况下,FF和 Opera的CSS解释标准更贴近CSS标准,也更具有规范性。



在不同浏览器下的CSS处理:
一般能够用!important来优先使用css语句(仅firefox支持)
比方:{border-width:0px!important;border-width:1px;}
在firefox下这个元素是没有边框的。在IE下边框宽度是1px 

几处XHTML与正常状态下的JS、CSS的差别
在网页开头加了这个代码就是所谓的XHTML标准了<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
XHTML标准下的几个不同点:
1.document.documentElement 与 document.body
代码中设置页面的CSS时一定要用:document.documentElement
比方:document.documentElement.style.overflow='hidden';
overflow-X、overflow-Y 这两个分坐标属性XHTML是不支持的;
2.在取得网页窗体区域和获取滚动栏位移距离时也要用document.documentElement
即这四个属性(clientWidth、clientHeight、scrollLeft、scrollTop)一定要用document.documentElement
可是document.body.appendChild()和document.body.removeChild()却是能够用的。并且用 document.documentElement.appendChild()和 document.documentElement.removeChild()取代却会报错;
总结一下仅clientWidth、clientHeight、scrollLeft、scrollTop和document.documentElement.style时才用document.documentElement
3.加了这个标准以后IE的边框问题也出现了变化,如今和firefox趋于一致了,是不是这个就是XHTML的长处——跨浏览器的标准
上面提到:
设置一个div的CSS::{width:100px;height:100px;border:#000000 1px solid;}
IE中(正常情况):div的宽度(包含边框宽度):100px,div的高度(包含边框宽度):100px;
firefox(正常情况)::div的宽度(包含边框宽度):102px,div的高度(包含边框宽度):102px;
加了XHTML标准后的(IE和firefox打和了,^_^):
IE中(XHTML):div的宽度(包含边框宽度):102px,div的高度(包含边框宽度):102px。
firefox(XHTML)::div的宽度(包含边框宽度):102px,div的高度(包含边框宽度):102px;

1.firefox中提交无效

    * 描写叙述:在项目中。用JS写了个提交(形如an.submit();当中an中表单名),但在firefox中执行时,点button却无效
    * 问题:在firefox中的JS,当form中没有submitbutton时,JS的submit会无效的
    * 解决:把button类型改成submit,若不想显示这个button的话。能够用CSS将其隐藏掉:    

    <input type='submit' style='display:none' />
2.firefox中显示模式对话框

    *描写叙述:想在firefox中显示一个模式对话框
    *问题:firefox中的JS没有window.showModalDialog这种方法,眼下似乎仅仅有Microsoft有!


    *解决:用例如以下方法表示:

window.open('openwin.html','newWin','modal=yes,width=200,height=200,resizable=no,scrollbars=no');

仅仅要在第三个參数中增加modal=yes就可以
3.firefox中JS对话框的结果传递

    *描写叙述:有这么一种需求,要求把用户在对话框中操作的结果返回给父窗体,在windows下,能够用window.returnVaule表示
    *问题:firefox中没有window.returnVaule这个属性
    *解决:在firefox中获得其父窗体的“引用”,再找到要更新值的组件,设置一下值就可以。表示方法例如以下:

假如在父窗体有一个form的标单,标单中有id=page这个text。那么在弹出的窗体中就能够这样对他覆值:parent.opener.document.form.page.value=newvalues;这样就能够完毕在弹出窗体对父窗体覆值的需求了。



window.event
IE中 能够使用window.event
FF中 event 仅仅能在事件发生的现场使用,能够改写成 事件=函数(event);
function somemethod(evt) {
evt = evt ? evt : (window.event ? window.event : null);
alert(evt);
}
比如: <input onclick=somemethod(event)>

4,event.x 与 event.y 问题
IE中,event 对象有 x, y 属性
FF中,可用event.clientX ,event.clientY替代(IE也有该属性)
也可用:mX = event.x ? event.x : event.pageX;
5,操作frame
IE中 能够用window.FrameName取得该frame,FF中不行
FF中 能够用window.top.document.getElementById(”frameId”)来訪问frame
注:IE和FF都能够通过window.top.document.getElementById(”Frame”).src = ’somefile.htm’来切换frame的 内容,也都能够通过window.top.frameName.location = ’somefile.htm’来切换frame的内容
6,调用showModalDialog
IE中能够用showModalDialog一个子窗体,并获得返回值.
FF中没有showModalDialog,但能够用window.open来实现.
比如:
在Main.cfm文件里有例如以下代码:
function ShowItemList(Obj){
if (document.all){//IE
var ReturnValue=window.showModalDialog(”ItemList.cfm?Id=341〃,”self”,”dialogwidth:500px;status:false”);
if (typeOf(ReturnValue)!=’undefined’){
Obj.value=ReturnValue;
}
}
else{
var subwin=window.open(Item.cfm?

id=341,’newWin’,’modal=yes,width=500px’);
}
}
function ReturnValue(ReturnValue){
Obj=document.getElementById(’elementname’);
Obj.value=ReturnValue;
}
假设须要得到返回值.须要用到window.open的參数modal=yes,并且必须在子窗体中向母窗体传值(window.opener).
比如在subwin.cfm中增加下面代码:
function ReturnThisValue(){
window.opener.ReturnValue(document.getElementById(’SelectedItem’).value);
}

IE和FIREFOX在解析CSS方面的差别
对高度的解析
IE:将依据内容的高度变化,包含没有定义高度的图片内容,即使定义了高度,当内容超过高度时。将使用实际高度

Firefox:未定义高度时,假设内容中包含了图片内容,MF的高度解析是依据印刷标准,这样就会造成和实际内容高度不符合的情况。当定义了高度,可是内容超过高度时,内容会超出定义的高度。可是区域使用的样式不会变化。造成样式错位。



结论:大家在能够确定内容高度的情况下最好定义高度,假设真的没有办法定义高度,最好不用使用边框样式,否则样式肯定会出现混乱!

img对象alt和title的解析
alt:当照片不存在或者load错误时的提示;

title:照片的tip说明。

在IE中假设未定义title,alt也能够作为img的tip使用。可是在MF中,两者全然依照标准中的定义使用

结论:大家在定义img对象时,最后将alt和title对象都写全,保证在各种浏览器中都能正常使用

其它的细节区别

当你在写css的时候。特别是用float: left(或right)排列一窜图片时,会发如今firefox里面正常而IE里面有问题。不管你用margin:0,还是border: 0来约束,都无济于事。

事实上这里还有另外一个问题,就是IE对于空格的处理。firefox是忽略的而IE对于块与块之间的空格是处理的。也就是说一个div结束后要紧接着一个div写。中间不要有回车或者空格。不然或许会有问题,比方3px的偏差。并且这个原因非常难发现。



很不走运的是我又碰到了这种问题,多个img标签连着,然后定义的float: left,希望这些图片能够连起来。可是结果在firefox里面正常而IE里面显示的每一个img都相隔了3px。我把标签之间的空格都删除都没有作用。



后来的解决方法是在img外面套li。而且对li定义margin: 0,这样就攻克了IE和firefox的显示偏差。IE对于一些模型的解释会产生非常多错误问题。仅仅有多多尝试才干发现原因。

这仅仅是一些简单的差别,在做布局和CSS设计时候能够综合考虑,但最为有效与简单的解决兼容问题还是用TABLE表格,表格在兼容性方面有着不错的表现.

nodeName 和 tagName 问题
(1)现有问题:
在MF中,全部节点均有 nodeName 值,但 textNode 没有 tagName 值。在 IE 中,
nodeName 的使用好象
有问题(详细情况没有測试。但我的IE已经死了好几次)。
(2)解决方法:
使用 tagName。但应检測其是否为空。