动态加载JavaScript文件的两种方法


Posted in Javascript onApril 22, 2016

这篇文章主要为大家详细介绍了动态加载JavaScript文件的两种方法,感兴趣的小伙伴们可以参考一下
第一种便是利用ajax方式,把script文件代码从背景加载到前台,而后对加载到的内容经过eval()实施代码。第二种是,动静创建一个script标签,配置其src属性,经过把script标签插入到页面head来加载js,相当于正在head中写了一个<script src="..."></script>,只可是这个script标签是用js动静创建的
比喻说是我们要动静地加载一个callbakc.js,我们就必要多么一个script标签:
代码如下:  

<script type="text/javascript" src="call.js"></script>

如下代码就是如何通过js来创建这个标签(并且加到head中): 
代码如下:

var head= document.getElementsByTagName('head')[0]; 
var script= document.createElement('script'); 
script.type= 'text/javascript'; 
script.src= 'call.js'; 
head.appendChild(script);

当加载完call.js, 我们就要调用其中的方法。不过在header.appendChild(script)之后我们不能马上调用其中的js。因为浏览器是异步加载这个js的,我们不知道他什么时候加载完。然而我们可以通过监听事件的办法来判断helper.js是否加载完成。(假设call.js中有一个callback方法) 代码如下:

var head= document.getElementsByTagName('head')[0]; 
var script= document.createElement('script'); 
script.type= 'text/javascript'; 
script.onreadystatechange= function () { 
if (this.readyState == 'complete') 
callback(); 
} 
script.onload= function(){ 
callback(); 
} 
script.src= 'helper.js'; 
head.appendChild(script);

我设了2个事件监听函数, 因为在ie中使用onreadystatechange, 而gecko,webkit 浏览器和opera都支持onload。事实上this.readyState == 'complete'并不能工作的很好,理论上状态的变化是如下步骤:
1.uninitialized
2.loading
3.loaded
4.interactive
5.complete
但是有些状态会被跳过。根据经验在ie7中,只能获得loaded和completed中的一个,不能都出现,原因也许是对判断是不是从cache中读取影响了状态的变化,也可能是其他原因。最好把判断条件改成this.readyState == 'loaded' || this.readyState == 'complete'

参考jQuery的实现我们最后实现为: 代码如下: 

var head= document.getElementsByTagName('head')[0]; 
var script= document.createElement('script'); 
script.type= 'text/javascript'; 
script.onload = script.onreadystatechange = function() { 
if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete" ) { 
help(); 
// Handle memory leak in IE 
script.onload = script.onreadystatechange = null; 
} }; 
script.src= 'helper.js'; 
head.appendChild(script);

还有一种简单的情况就是可以把help()的调用写在helper.js的最后,那么可以保证在helper.js在加载完后能自动调用help(),当然最后还要能这样是不是适合你的应用。

另外需要注意:

1.因为script标签的src可以跨域访问资源,所以这种方法可以模拟ajax,解决ajax跨域访问的问题。
2.如果用ajax返回的html代码中包含script,则直接用innerHTML插入到dom中是不能使html中的script起作用的。粗略的看了下jQuery().html(html)的原代码,jQuery也是先解析传入的参数,剥离其中的script代码,动态创建script标签,所用jQuery的html方法添加进dom的html如果包含script是可以执行的。如:  
 

jQuery("#content").html("<script>alert('aa');<\/script>");

以上就是动态加载JavaScript文件的方法,希望对大家的学习有所帮助。

Javascript 相关文章推荐
关于Ext中form移除textfield方法:hide(),setVisible(false),remove()
Dec 02 Javascript
JavaScript实现x秒后自动跳转到一个页面
Jan 03 Javascript
JS获取URL中参数值(QueryString)的4种方法分享
Apr 12 Javascript
JS实现不使用图片仿Windows右键菜单效果代码
Oct 22 Javascript
AngularJs 弹出模态框(model)
Apr 07 Javascript
js实现可控制左右方向的无缝滚动效果
May 29 Javascript
前端防止用户重复提交js实现代码示例
Sep 07 Javascript
vue2 设置router-view默认路径的实例
Sep 20 Javascript
优雅的在React项目中使用Redux的方法
Nov 10 Javascript
Vue 中使用 typescript的方法详解
Feb 17 Javascript
toString.call()通用的判断数据类型方法示例
Aug 28 Javascript
JS数组索引检测中的数据类型问题详解
Jan 11 Javascript
JavaScript记录光标在编辑器中位置的实现方法
Apr 22 #Javascript
在AngularJS中使用jQuery的zTree插件的方法
Apr 21 #Javascript
AngularJS中实现用户访问的身份认证和表单验证功能
Apr 21 #Javascript
解决JS组件bootstrap table分页实现过程中遇到的问题
Apr 21 #Javascript
javascript常见数字进制转换实例分析
Apr 21 #Javascript
BootStrap和jQuery相结合实现可编辑表格
Apr 21 #Javascript
动态加载js文件简单示例
Apr 21 #Javascript
You might like
一个用php实现的获取URL信息的类
2007/01/02 PHP
PHP与SQL注入攻击[一]
2007/04/17 PHP
PHP写日志的实现方法
2014/11/05 PHP
jquery获取多个checkbox的值异步提交给php的方法
2015/06/24 PHP
zend framework中使用memcache的方法
2016/03/04 PHP
PHP入门教程之数学运算技巧总结
2016/09/11 PHP
php实现给二维数组中所有一维数组添加值的方法
2017/02/04 PHP
php如何把表单内容提交到数据库
2019/07/08 PHP
php array_chunk()函数用法与注意事项
2019/07/12 PHP
js下将字符串当函数执行的方法
2011/07/13 Javascript
比较新旧两个数组值得增加和删除的JS代码
2013/10/30 Javascript
JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)
2014/08/16 Javascript
Thinkphp模板没有解析直接原样输出的解决方法
2014/10/31 Javascript
Boostrap模态窗口的学习小结
2016/03/28 Javascript
微信小程序 视图容器组件的详解及实例代码
2017/01/19 Javascript
JavaScript常用正则函数用法示例
2017/01/23 Javascript
Vue 父子组件的数据传递、修改和更新方法
2018/03/01 Javascript
使用 Node.js 实现图片的动态裁切及算法实例代码详解
2018/09/29 Javascript
vue使用v-if v-show页面闪烁,div闪现的解决方法
2018/10/12 Javascript
Nuxt.js 数据双向绑定的实现
2019/02/17 Javascript
Vue2.0实现简单分页及跳转效果
2019/07/29 Javascript
vue实现简单加法计算器
2020/10/22 Javascript
详解Vue3 Teleport 的实践及原理
2020/12/02 Vue.js
Python 数据结构之堆栈实例代码
2017/01/22 Python
浅谈Python2、Python3相对路径、绝对路径导入方法
2018/06/22 Python
python3.4爬虫demo
2019/01/22 Python
Python序列化与反序列化pickle用法实例
2019/11/11 Python
flask框架配置mysql数据库操作详解
2019/11/29 Python
python中pdb模块实例用法
2021/01/15 Python
网页布局中CSS样式无效的十个重要原因详解
2017/08/10 HTML / CSS
远程调用的原理
2014/07/05 面试题
初中家长寄语
2014/04/02 职场文书
精神文明建设先进个人事迹材料
2014/12/24 职场文书
幼儿园春季开学通知
2015/07/16 职场文书
python全面解析接口返回数据
2022/02/12 Python
Python如何使用循环结构和分支结构
2022/04/13 Python