仅IE9/10/(Opera)同时支持script元素的onload和onreadystatechange事件
如下
1 2 3 4 5 6 7 8 9 10 | <!DOCTYPE HTML> <html> <head> <meta charset= "utf-8" > <title>IE9/10同时支持script元素的onload和onreadystatechange事件</title> <script src= "http://code.jquery.com/jquery.min.js" onload= "alert(1)" onreadystatechange= "alert(2)" ></script> </head> <body> </body> </html> |
结果:
IE6/7/8 : 弹出2
IE9/10 : 弹出2,1
Firefox/Safari/Chrome/Opera : 弹出1
测试结果可以看出,IE9后已经开始支持script的onload事件了。一直以来我们判断js文件是否已经加载完成就是用以上的两个事件。很久以前就知道IE中使用onreadystatechange事件,事件handler中使用readyState的值判断是否加载完成。其它浏览器使用onload事件。
1 2 3 4 5 6 7 8 9 10 11 | if (isIE) { script.onreadystatechange = function () { if ( this .readyState == 'loaded' || this .readyState == 'complete' ) { callback(); } } } else { script.onload = function () { callback(); } } |
这种写法现在也没有问题。但如下写法可能会让的回调在IE9/10中执行两次
1 2 3 4 5 | 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次。
注意:动态创建的script在Opera中是支持onreadystatechange事件的
相关:
http://www.w3.org/TR/html401/interact/scripts.html#h-18.2.1
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端