js如何判断引入的js文件是否加载完毕


js如何判断引入的js文件是否加载完毕:

如果javascript代码较少的话完全可以将js代码通过<script></script>标签写在当前页面,但是如果js代码非常庞大的话,那么页面将会变得非常的臃肿,并且由于js代码是同步加载,所以当js代码加载的时候,会阻塞下面内容的解析,所以最好能够动态加载js功能,尤其是能够实现根据需要动态引入外部js文件。由于动态加载js文件是异步的,所以有时候需要判断js文件是否加载完毕,下面就通过代码介绍一下如何实现判断功能。

代码如下:


function dynamicLoad(){
  var _doc=document.getElementsByTagName('head')[0];
  var script=document.createElement('script');
  script.setAttribute('type','text/javascript');
  script.setAttribute('src','jquery-1.8.3.js');
  _doc.appendChild(script);
  script.onload=script.onreadystatechange=function(){
    if(!this.readyState||this.readyState=='loaded'||this.readyState=='complete'){
      alert('done');
    }
    script.onload=script.onreadystatechange=null;
  }
}


上面你的代码实现了js文件加载是否完成的功能,下面介绍一下它的实现过程。

一.代码注释:

1.function dynamicLoad(){},此函数实现判断指定文件是否加载完毕的功能。
2.var _doc=document.getElementsByTagName('head')[0],获取head头部标签元素对象。
3.var script=document.createElement('script'),创建一个script标签元素。
4.script.setAttribute('type','text/javascript'),设置script标签的type属性。
5.script.setAttribute('src','jquery-1.8.3.js'),设置script标签的src属性值,也就是要加载js文件的路径。
6._doc.appendChild(script),将script标签附加到head标签中,否则只能够在IE11以下浏览器能够完成判断。
7.script.onload=script.onreadystatechange=function(){
   if(!his.readyState||this.readyState=='loaded'||this.readyState=='complete'){
     alert('done');
   }
   script.onload=script.onreadystatechange=null;
}

上面你的代码的分析可以参阅script.onload=script.onreadystatechange=function()的作用一章节。

8.script.onload=script.onreadystatechange=null,删除事件处理函数。

二.相关阅读:

1.getElementsByTagName()函数可以参阅document.getElementsByTagName()一章节。

2.createElement()函数可以参阅js的createElement()和appendChild()函数的作用一章节。

3.setAttribute()函数可以参阅setAttribute()函数的用法详解一章节。


原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=14775


返回顶部
跳到底部

Copyright 2011-2024 南京追名网络科技有限公司 苏ICP备2023031119号-6 乌徒帮 All Rights Reserved Powered by Z-BlogPHP Theme By open开发

请先 登录 再评论,若不是会员请先 注册