前端开发

 首页 > 前端开发 > javascript > javascript 同步、异步各种执行方式的顺序讲解

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

分享到:
【字体:
导读:
          本文讲解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文件中的


2、


Java代码

 //同步加载执行xx.js中的代码


3、 

JavaScript代码

'); //异步加载执行xx.js中的代码   

 


4、


Java代码

 

zong.js中有下面代码:


Java代码

document.write('');   
document.write('');

  

则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 加载之后被浏览器缓存.


分享到:
Javascript通过创建iframe异步加载解决跨...
本文讲解Javascript通过创建iframe异步加载解决跨域问题 很多情况下广告的同步加载会影响大主页面的加载,导致主页面的onload事件的执行被延迟,这里提供了一个简单的异步加载广告的方法。 例如a.html为主页面 XML/HTML代码              test page                           ...
浅谈js数组去重的方法汇总
浅谈js数组去重的方法汇总 三种方法 利用indexOf判断新数组 underscore.js中实际上也是使用的类似的indexOf  //传入数组  function unique1(arr){   var tmpArr = [];   for(var i=0; i s {1, 2, 3, 4} >>> s.add(4) >>> s {1, 2, 3, 4}//重复元素不会被添加 删除元素 s; // Set {1, 2,...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……