网站地图    收藏   

主页 > 前端 > javascript >

javascript 同步、异步各种执行方式的顺序讲解

来源:未知    时间:2015-07-29 11:51 作者:xxadmin 阅读:

[导读] 本文讲解javascript 同步、异步各种执行方式的顺序讲解 script 标签在HTML5中除了具备HTML5新标准定义的属性以外,和HTML4.01相比移除了language属性,修改了type属性为可选的(默认text/javasc...

本文讲解javascript 同步、异步各种执行方式的顺序讲解

script 标签在HTML5中除了具备HTML5新标准定义的属性以外,和HTML4.01相比移除了language属性,修改了type属性为可选的(默认text/javascript),并新增了一个属性async。

async :boolean, 属性的作用,定义脚本是否异步执行,取值true或false。 

如果 async 设为 true ,会忽略 defer 属性。 

异步执行的 js 文件被假定为不使用 


JavaScript代码

document.write()

  

向加载中的 document 写入内容,因此不要在 异步执行的 js 文件的加载执行过程中使用 


JavaScript代码

document.write()

 


除了 script 标签属性外,页面引入 js 文件的方式影响其加载执行方式: 

任何以添加 script 节点(例如 appendChild(scriptNode) ) 的方式引入的js文件都是异步执行的 (scriptNode 需要插入document中,只创建节点和设置 src 是不会加载 js 文件的,这跟 img 的预加载不能类比 )

html文件中的<script>标签中的代码或src引用的js文件中的代码是同步加载和执行的 

html文件中的<script>标签中的代码使用


JavaScript代码

document.write()

 

方式引入的js文件是异步执行的 

html文件中的<script>标签src属性所引用的js文件的代码内再使用


JavaScript代码

document.write()

方式引入的js文件是同步执行的 

使用 Image 对象异步预加载 js 文件(不会被执行)


window.onload 事件会在 js 文件加载完毕才触发(即使是异步加载)


1、


PHP代码

<script>   
//同步加载执行的代码   
</script>


2、


Java代码

<script src="xx.js"></script> //同步加载执行xx.js中的代码


3、 

JavaScript代码

<script>   
document.write('<script src="xx.js"><\/script>'); //异步加载执行xx.js中的代码   
</script>

 


4、


Java代码

<script src="zong.js"></script>

 

zong.js中有下面代码:


Java代码

document.write('<script src="11.js"><\/script>');   
document.write('<script src="22.js"><\/script>');

  

则zong.js和11.js、22.js 都是同步加载和执行的。

如果 zong.js 、11.js 和 22.js 以插入 script 节点方式异步加载,则 11.js 和 22.js 是异步加载的, 

如果 zong.js 以script 节点方式异步加载, 11.js 和 22.js 以 


Java代码

document.write(script)

 方式加载,则 11.js 和 22.js 是同步加载的(经最新的浏览器测试, 在chrome 下,xx.j 异步加载执行已经无法使用 


Java代码

document.write()

 向文档写入内容的 ,但是 firefox 和IE 却可以在 document 关闭之前写入(方法是在 html 中alert阻止文档关闭)) 

测试:在11.js中 alert(不要用 for 循环,浏览器是单线程执行的,持续执行任何一段代码都会导致其余代码被阻塞) , 22.js 中 console.log ,可以看到 22.js中的代码被阻塞


5、 

下面这种方式,xx.js会在appendChild执行之后异步加载执行


Java代码

var script = document.createElement("script");   
 script.setAttribute("src","xx.js");   
 documenrt.getElementsByTagName("head")[0].appendChild(script);

  

6、使用 Image 对象异步预加载 js 文件(不会被执行) 

Image 的 src 被赋值时即发起请求,而且对文件类型不挑剔(图片也可能是有脚本动态创建的,比如验证码),因此可以将 js 文件的 url 赋给 image.src, js 加载之后被浏览器缓存.


自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论