Firefox和IE浏览器兼容JS脚本写法小结_Javascript教程-查字典教程网
Firefox和IE浏览器兼容JS脚本写法小结
Firefox和IE浏览器兼容JS脚本写法小结
发布时间:2016-12-30 来源:查字典编辑
摘要:1.window.event兼容脚本functiongetEvent(){//获取浏览器事件,同时兼容ie和ff的写法if(document...

1.window.event兼容脚本

functiongetEvent(){//获取浏览器事件,同时兼容ie和ff的写法

if(document.all)returnwindow.event;

func=getEvent.caller;

while(func!=null){

vararg0=func.arguments[0];

if(arg0){

if((arg0.constructor==Eventarg0.constructor==MouseEvent)

(typeof(arg0)=="object"&&arg0.preventDefault&&arg0.stopPropagation)){

returnarg0;

}

}

func=func.caller;

}

returnnull;

}

每次用事件之前Firefox都需要用getEvent()获取一下,否则就是空

2.屏蔽Form提交事件

event.returnValue=false;//forIE

evt.preventDefault();//forfirefox

3.获取事件源

varsource=event.srcElement//IE

varsource=event.target//firefox

4.添加事件兼容写法

functionaddEvent(oElement,sEvent,func){

if(oElement.attachEvent){

oElement.attachEvent(sEvent,func);

}

else{

sEvent=sEvent.substring(2,sEvent.length);

oElement.addEventListener(sEvent,func,false);

}

}

用法:addEvent(window,"onload",Start);

5.Firefox注册innerText写法

//注册firefoxinnerText

HTMLElement.prototype.__defineGetter__("innerText",

function(){

varanyString="";

varchildS=this.childNodes;

for(vari=0;iif(childS[i].nodeType==1)

anyString+=childS[i].tagName=="BR"?'n':childS[i].innerText;

elseif(childS[i].nodeType==3)

anyString+=childS[i].nodeValue;

}

returnanyString;

}

);

HTMLElement.prototype.__defineSetter__("innerText",

function(sText){

this.textContent=sText;

}

);

6.长度:FireFox长度必须加“px”,IE无所谓

7.父控件下的子控件:IE是“children”,FireFox是“childNodes”

8.XmlHttp

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

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类