您现在的位置:首页 --> JavaScript --> JS文件加载失败处理
JS文件加载失败处理
浏览:2493次 出处信息
浏览器的文件加载实际上是有非常纠结的兼容问题的。最近看到@lifesinger做了一个具体的总结。这里比较麻烦的是IE6~8不区分加载成功或失败,都走一个回调。在网上看了一种解决方案是,在加载文件的最后置一个全局变量或改变标签的属性来区分,这样成功与否就通过这个标志位判断。但显然不太完美,还要改加载文件。
后来尝试另一种思路,先创建一个vbscript,src置成一个JS文件,如这个文件加载正常,肯定会报错否则不会有反应。这样如果window.onerror捕获到错误了,说明文件有效,再正常加载。如果没捕获到,n秒后会触发一个超时。
这部分代码:
if(ie && ie < 9) { vbs = doc.createElement(\'script\'); vbs.language = \'vbscript\'; vbs.src = file; saveErrorHandle = win.onerror; win.onerror = function() { load(); win.onerror = saveErrorHandle; return true; }; setTimeout(function(){ ref.parentNode.insertBefore(vbs, ref); }, 0); } else { load(); }
DEMO: http://hikejun.com/demo/demo_js_errorback.html
建议继续学习:
- php无法加载pcre.so的解决办法 (阅读:2895)
- 用C++面向对象的方式动态加载so (阅读:2776)
- 一个IE6下重复加载的BUG (阅读:2733)
- IE6图片加载的一个BUG (阅读:2588)
- 渐进式的脚本加载 (阅读:2297)
- 动态加载JavaScript的小实践 (阅读:2124)
- 交互模式之分页还是加载? (阅读:1823)
- 关于Feed流信息的加载方式 (阅读:1645)
- 加载,不只是少一点点 (阅读:1554)
- 内容loading加载后高度变化CSS3 transition体验优化 (阅读:1548)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:IE中Image .onload方法问题
后一篇:正则表达式字面量在ECMAScript5中的变化 >>
文章信息
- 作者:kejun 来源: Kejun's Blog
- 标签: 加载
- 发布时间:2011-05-17 08:42:19
建议继续学习
近3天十大热文
- [705] WEB系统需要关注的一些点
- [331] 如何拿下简短的域名
- [17] 移动音乐产品梳理
- [15] 豆瓣是啥?
- [14] Perl 的线程中的共享
- [13] 一个 VLA (可变长度数组)的实现
- [13] UMStor Hadapter:大数据与对象
- [13] 内存的惰性初始化
- [12] Chrome开发者工具的小技巧
- [12] 为什么工程师会造出蹩脚的产品