您好,欢迎访问一九零五行业门户网

仅IE9/10同时支持script元素的onload和onreadystatechange事件分析_javascript技巧

如下
复制代码 代码如下:
ie9/10同时支持script元素的onload和onreadystatechange事件
结果:
ie6/7/8 : 弹出2
ie9/10 : 弹出2,1
firefox/safari/chrome/opera : 弹出1
测试结果可以看出,ie9后已经开始支持script的onload事件了。一直以来我们判断js文件是否已经加载完成就是用以上的两个事件。很久以前就知道ie中使用onreadystatechange事件,事件handler中使用readystate的值判断是否加载完成。其它浏览器使用onload事件。
复制代码 代码如下:
if(isie){
script.onreadystatechange = function(){
if(this.readystate == 'loaded' || this.readystate == 'complete'){
callback();
}
}
}else{
script.onload = function(){
callback();
}
}
这种写法现在也没有问题。但如下写法可能会让的回调在ie9/10中执行两次
复制代码 代码如下:
script.onload = script.onreadystatechange = function(){
if(!this.readystate || this.readystate == loaded || this.readystate == complete){
callback();
}
}
这种写法的取巧之处在于onload和onreadystatechage都用同一个函数,firefox/safari/chrome/opera中不支持onreadystatechage事件,也没有readystate属性,所以 !this.readystate 是针对这些浏览器。readystate是针对ie浏览器,载入完毕的情况是loaded,缓存的情况下可能会出现readystate为complete。所以两个不能少。但由于ie9/10也已经支持onload事件了,会造成callback执行2次。
相关:
http://www.w3.org/tr/html401/interact/scripts.html#h-18.2.1 
http://www.w3.org/tr/html5/scripting-1.html#script
https://developer.mozilla.org/en/html/element/script
其它类似信息

推荐信息