建站学 - 轻松建站从此开始!

建站学-个人建站指南,网页制作,网站设计,网站制作教程

IE9/10同时支持script元素的onload和onreadystatechange事件分析测试

时间:2011-04-27 16:40来源: 作者: 点击:
IE9/10同时支持script元素的onload和onreadystatechange事件分析测试
 

如下

01 <!DOCTYPE HTML>
02 <html>
03     <head>
04         <meta charset="utf-8">
05         <title>IE9/10同时支持script元素的onload和onreadystatechange事件</title>
06         <script src="http://code.jquery.com/jquery.min.js" onload="alert(1)" onreadystatechange="alert(2)"></script>
07     </head>
08     <body>
09     </body>
10 </html>

结果:

IE6/7/8 : 弹出2

IE9/10 : 弹出2,1

Firefox/Safari/Chrome/Opera : 弹出1


测试结果可以看出,IE9后已经开始支持script的onload事件了。一直以来我们判断js文件是否已经加载完成就是用以上的两个事件。很久以前就知道IE中使用onreadystatechange事件,事件handler中使用readyState的值判断是否加载完成。其它浏览器使用onload事件。

01 if(isIE){
02     script.onreadystatechange = function(){
03         if(this.readyState == 'loaded' || this.readyState == 'complete'){
04             callback();
05         }
06     }
07 }else{
08     script.onload = function(){
09         callback();
10     }
11 }

这种写法现在也没有问题。但如下写法可能会让的回调在IE9/10中执行两次

1 script.onload = script.onreadystatechange = function(){
2     if(!this.readyState || this.readyState == "loaded" || this.readyState == "complete"){
3         callback();
4     }
5 }

这种写法的取巧之处在于onload和onreadystatechage都用同一个函数,Firefox/Safari/Chrome/Opera中不支持onreadystatechage事件,也没有readyState属性,所以 !this.readyState 是针对这些浏览器。readyState是针对IE浏览器,载入完毕的情况是loaded,缓存的情况下可能会出现readyState为complete。所以两个不能少。但由于IE9/10也已经支持onload事件了,会造成callback执行2次。

(责任编辑:admin)
织梦二维码生成器
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片