JavaScript重构(二):JS的动态加载
来源:互联网 发布:源码商城 编辑:程序博客网 时间:2024/06/05 08:07
前一节留下了一个问题,如果JS分门别类也清晰了,那我现在需要在必要的情况下才加载某一模块的JS,这个怎么实现呢?
方法一,最简单也是最容易被接受的方法,通过后台代码来控制,还是少些复杂的JS吧,通过一个标签、一个分支判断,就可以做到,何乐而不为呢?
方法二,如果要使用纯JS来控制,那么看看这样如何:
Js代码
$.ajax(){
url:"xxx/play.js";
……
success:function(res){
eval(res.responseText);
}
}
原理是很简单,不过有一个藏匿着的魔鬼:eval,js加载的生效就靠它了,那么执行的上下文就在它的里面,这就会带来一些潜在的问题,而且,调试也变得困难。
方法三,通过添加<script>标签的方式来动态引入脚本:
原理相信大家也马上能领悟个大概了,需要的时候动态地往页面的<head>里面写一对<script>标签,让浏览器自己去取需要的js,这样的就解决了方法二里面的魔鬼eval的问题,是一个比较好的方法:
Js代码
<script src="xxx/play.js" ... />
这里啰嗦一句,<script>标签中的src——本质上不就是对src所表示的地址发送一个get请求吗?这虽然看起来有点歪门邪道,却恰恰是一个跨域问题的解决办法!因为浏览器对<script>引用js页面可没有同域的安全限制(以前转载过过一篇跨域问题的讨论,见此)。
方法四,很多JS框架都提供了易于使用的JS动态加载的方法,比如JQuery的loadScript方法,这里不讨论了。
另外,如果使用上pushlet的方法,对一个js文件无止境地读取,能否实现这样的效果呢?仅作设想,希望有人与我讨论。
方法一,最简单也是最容易被接受的方法,通过后台代码来控制,还是少些复杂的JS吧,通过一个标签、一个分支判断,就可以做到,何乐而不为呢?
方法二,如果要使用纯JS来控制,那么看看这样如何:
Js代码
$.ajax(){
url:"xxx/play.js";
……
success:function(res){
eval(res.responseText);
}
}
原理是很简单,不过有一个藏匿着的魔鬼:eval,js加载的生效就靠它了,那么执行的上下文就在它的里面,这就会带来一些潜在的问题,而且,调试也变得困难。
方法三,通过添加<script>标签的方式来动态引入脚本:
原理相信大家也马上能领悟个大概了,需要的时候动态地往页面的<head>里面写一对<script>标签,让浏览器自己去取需要的js,这样的就解决了方法二里面的魔鬼eval的问题,是一个比较好的方法:
Js代码
<script src="xxx/play.js" ... />
这里啰嗦一句,<script>标签中的src——本质上不就是对src所表示的地址发送一个get请求吗?这虽然看起来有点歪门邪道,却恰恰是一个跨域问题的解决办法!因为浏览器对<script>引用js页面可没有同域的安全限制(以前转载过过一篇跨域问题的讨论,见此)。
方法四,很多JS框架都提供了易于使用的JS动态加载的方法,比如JQuery的loadScript方法,这里不讨论了。
另外,如果使用上pushlet的方法,对一个js文件无止境地读取,能否实现这样的效果呢?仅作设想,希望有人与我讨论。
阅读全文
0 0
- JavaScript重构(二):JS的动态加载
- JavaScript重构(二):JS的动态加载
- javascript动态加载二
- javascript动态加载二
- javascript 动态加载css、js
- javascript 动态加载css、js
- JavaScript动态加载js文件
- javascript动态加载js文件
- JavaScript 元素的插入顺序以及动态加载js
- 如何运行时(动态)加载js脚本|JavaScript
- JavaScript实现动态加载其他的js文件-(咋个办呢 zgbn)
- 实战javascript之动态加载js和动态加载css
- JS动态加载JavaScript和Css
- JavaScript 动态加载 其它JS文件
- Javascript:动态加载JS两种方式!
- JavaScript动态加载css和js文件
- JavaScript动态加载CSS和JS文件
- 重识JavaScript(二)
- QT学习——文件操作
- 台湾大学林轩田机器学习技法课程学习笔记5 -- Kernel Logistic Regression
- OC-集合类(数组)
- JavaScript重构(三):JavaScript的测试
- Redis的基本数据类型
- JavaScript重构(二):JS的动态加载
- SSH简单项目实例(附下载)
- 背包问题解析
- JS-RegExp正则表达式的对象
- JavaScript重构(一):模块划分和命名空间
- Java.lang.StringBuilder常用类
- Scala练习-插值查找
- JavaScript重构(九):自定义的JavaScript产品框架
- SQL Server 表变量和临时表的区别