黄聪:异步加载JS的4种方式(详解)
来源:互联网 发布:仙界网络直播间80txt 编辑:程序博客网 时间:2024/05/21 07:52
方案1:$(document).ready
<!DOCTYPE html><html> <head> <script src="http://common.cnblogs.com/script/jquery.js" type="text/javascript"></script> <script type="text/javascript"> $(document).ready(function() { alert("加载完成!"); }); </script> </head> <body> <img src="http://images.cnitblog.com/i/121863/201405/222202573569862.jpg" /> </body></html>
点评:
1、需要引用jquery
2、兼容所有浏览器。
方案2:<script>标签的async="async"属性
async的定义和用法(是HTML5的属性)
async 属性规定一旦脚本可用,则会异步执行。
示例:
<script type="text/javascript" src="xxxxxxx.js" async="async"></script>
点评:
1、HTML5中新增的属性,Chrome、FF、IE9&IE9+均支持(IE6~8不支持)。此外,这种方法不能保证脚本按顺序执行。
2、async 属性仅适用于外部脚本(只有在使用 src 属性时)。
方案3:<script>标签的defer="defer"属性
defer 属性规定是否对脚本执行进行延迟,直到页面加载为止。
有的 javascript 脚本 document.write 方法来创建当前的文档内容,其他脚本就不一定是了。
如果您的脚本不会改变文档的内容,可将 defer 属性加入到 <script> 标签中,以便加快处理文档的速度。因为浏览器知道它将能够安全地读取文档的剩余部分而不用执行脚本,它将推迟对脚本的解释,直到文档已经显示给用户为止。
示例:
<script type="text/javascript" defer="defer"> alert(document.getElementById("p1").firstChild.nodeValue); </script>
点评:兼容所有浏览器。此外,这种方法可以确保所有设置defer属性的脚本按顺序执行。
方案4:动态创建<script>标签
示例:
<!DOCTYPE html><html> <head> <script type="text/javascript"> (function(){ var s = document.createElement('script'); s.type = 'text/javascript'; s.src = "http://code.jquery.com/jquery-1.7.2.min.js"; var tmp = document.getElementsByTagName('script')[0]; tmp.parentNode.insertBefore(s, tmp); })(); </script> </head> <body> <img src="http://images.cnitblog.com/i/121863/201405/222202573569862.jpg" /> </body></html>
点评:兼容所有浏览器。
0 0
- 黄聪:异步加载JS的4种方式(详解)
- JS异步加载的三种方式
- 异步加载js的五种方式
- 异步加载JS的五种方式
- JS异步加载的三种方式
- js异步加载的三种方式
- JS异步加载的三种方式
- JavaScript异步加载的4种方式
- js异步加载详解
- Javascript 异步加载详解(浏览器在javascript的加载方式)
- Javascript 异步加载详解(浏览器在javascript的加载方式)
- Javascript 异步加载详解(浏览器在javascript的加载方式)
- Javascript 异步加载详解(浏览器在javascript的加载方式)
- Android异步加载图片详解之方式一(4)
- js异步加载的三种解决方案
- js异步加载的三种解决方案
- js异步加载的三种解决方案
- js异步加载的三种解决方案
- 根据属地id选择子属地
- 手把手教你封装一个vue component
- TODAY ISSUE
- Fiddler抓取https的原理
- matlab2016a自带的disparity函数
- 黄聪:异步加载JS的4种方式(详解)
- Java学习之权限修饰符与常见内容修饰
- 卡牌游戏II
- QT图形界面在工业数据采集显示系统的应用
- python os.path模块学习
- 由App的启动说起
- VirtualBox挂载Linux之后,启动报错:Error relaunching VirtualBox VM process: 5 .
- 状态模式(State Pattern)
- angular 里$$hashkey问题?