对比requirejs更好的理解seajs
seajs遵循CMD规范,requirejs遵循AMD规范。AMD规范是预加载,CMD规范是赖加载。
下文举例假设有文件 b.js, c.js如下
//b.js
define(function(require, exports, module){
console.log('b is loaded') function run(){
console.log('b run');
}
exports.run = run;
}) //c.js
define(function(require, exports, module){
console.log('c is loaded') function run(){
console.log('c run');
}
exports.run = run;
})
1. seajs对依赖模块只加载不执行,requirejs对依赖模块既加载也执行
运行代码:
// seajs
<!DOCTYPE html>
<html>
<head>
<title>seajs</title>
<script type="text/javascript" src="./sea.min.js"></script>
</head>
<body>
<button id="btn">OK</button>
<script type="text/javascript">
seajs.use('./a.js')
</script>
</body>
</html> // requirejs
<!DOCTYPE html>
<html>
<head>
<title>requirejs</title>
<script type="text/javascript" src="./require.js"></script>
</head>
<body>
<button id="btn">OK</button>
<script type="text/javascript">
require(['a'])
</script>
</body>
</html> // a.js
define(['b'], function(){
})
运行结果:
seajs:
控制台无输出
requirejs:
控制台:
2. seajs ,requirejs在 require文件时既加载也执行
//a.js
define(function(require, exports, module){
var b = require('b')
})
requirejs:
控制台:b is loaded
seajs:
控制台:b is loaded
3. seajs可以在任意处直接require文件,无需提前写依赖模块;一旦提前写了任意一个依赖模块,下面的所有require的使用必须保证也有其对应的依赖模块
seajs可以直接如下使用,无需写依赖['b']:
//a.js
define(function(require, exports, module){
var b = require('b')
}) 或
define(['b'], function(require, exports, module){
var b = require('b')
})
运行结果:
控制台:b is loaded
假如 a.js 依赖了另一个 c.js,则在 a.js 中使用 require('b') 时必须也写上依赖['b'],否则b.js将因为查找不到而不会加载
define(['c'], function(require, exports, module){
var b = require('b')
})
运行结果:
控制台无输出(不会输出c is loaded, 因为没有require('c') )
如果此时我们执行b.run()
define(['c'], function(require, exports, module){
var b = require('b')
b.run()
})
控制台将会报错,因为此时b为null:
此时正确写法应该写上依赖 ['b']:
define(['c', 'b'], function(require, exports, module){
var b = require('b')
b.run()
})
运行结果:
结论:
对于seajs,如果不写依赖那就一个都不要写,一旦写了,下面所有require的地方都需要提前在头部写上依赖
但对require.ascnc例外,可以如下写法:
//a.js
define(['c'], function(require, exports, module){
var b = require.async('b');
})
此时c.js, b.js都被加载,只有 b.js 被执行
下一点将会介绍require.async
requirejs的依赖写法如下:
define(['c', 'b'], function(c, b){
var b = require('b')
b.run()
}) 或 define(function(require, exports, module){
var b = require('b')
b.run()
}) //错误写法
define(['c'], function(c){
var b = require('b')
b.run()
})
4. seajs的require.async在执行到使用位置的时候才去异步加载
seajs:
如下例:
// a.js
define(function(require, exports, module){
document.getElementById('btn').addEventListener('click', function(){
document.getElementById('btn').innerHTML = 'btn is clicked'
init()
}) function init(){
var b = require('b');
b.run()
}
})
运行结果:
控制台无输出
点击OK按钮, b.js 加载并执行b.js和run方法:
大家注意到,在未点击按钮之前,虽然没有执行init方法,但b.js依然被提前加载了进来,但没有被执行(没有输出b is loaded)。
很多时候我们想在执行init方法的时候再去加载b.js,而不是提前在页面加载的时候就把b,js加载。
这时候就需要用到require.async,如下:
//a.js
define(function(require, exports, module){
document.getElementById('btn').addEventListener('click', function(){
document.getElementById('btn').innerHTML = 'btn is clicked'
init()
}) function init(){
require.async('b', function(b){
b.run()
});
}
})
这时候运行结果:
b.js没有被加载:
控制台无输出:
点击OK按钮:
b.js被加载
控制台输出:
这是因为当执行一个js时,seajs会先去查找匹配require,然后加载相应资源,但不执行。匹配到require.async时不加载。
所以,require.async达到了用到时再去异步加载并执行的目的。
小问题:
如果是requirejs执行下面代码:
//a.js
define(function(require, exports, module){
document.getElementById('btn').addEventListener('click', function(){
document.getElementById('btn').innerHTML = 'btn is clicked'
init()
}) function init(){
var b = require('b');
b.run()
}
})
资源如何加载?控制台又会输出什么呢?点击ok按钮又会输出啥?
答:资源加载了a.js, b.js, 控制台输出:b is loaded, 点击OK按钮控制台继续输出:b run
(选择“答”后面的部分查看答案)
总结: 1. seajs对依赖模块只加载不执行,requirejs对依赖模块加载并执行 2. seajs ,requirejs在 require具体文件时既加载也执行 3. seajs可以在任意处直接require文件,无需提前写依赖模块;一旦提前写了任意一个依赖模块,下面的所有require的使用必须保证也有其对应的依赖模块 4. seajs的require.async在执行到使用位置的时候才去异步加载
本文demo:
https://github.com/saysmy/seajs-requirejs-demo
对比requirejs更好的理解seajs的更多相关文章
- seaJS 简单例子,理解seaJS
学习心得: 记得第一次学underscore的时候,去的官网(不管什么都是官网好),呼啦一长列语法,我就一个个看,看完也不知道underscore是做什么的.就是现在underscore我也用不上,学 ...
- 通过Ruby On Rails 框架来更好的理解MVC框架
通过Ruby On Rails 框架来更好的理解MVC框架 1.背景 因为我在学习软件工程课程的时候,对于 MVC 框架理解不太深入,只是在理论层面上掌握,但是不知道如何在开发中使用 MVC ...
- dimensionality reduction动机---visualization(将数据可视化帮助我们更好地理解数据)
如果我们能更好地理解我们的数据,这样会对我们开发高效的机器学习算法有作用,将数据可视化(将数据画出来能更好地理解数据)出来将会对我们理解我们的数据起到很大的帮助. 高维数据如何进行显示 GDP: gr ...
- 嗯 第二道线段树题目 对左右节点和下标有了更深的理解 hdu1556
Color the ball Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- 帮助你更好的理解Spring循环依赖
网上关于Spring循环依赖的博客太多了,有很多都分析的很深入,写的很用心,甚至还画了时序图.流程图帮助读者理解,我看了后,感觉自己是懂了,但是闭上眼睛,总觉得还没有完全理解,总觉得还有一两个坎过不去 ...
- 技术干货 | 基于MindSpore更好的理解Focal Loss
[本期推荐专题]物联网从业人员必读:华为云专家为你详细解读LiteOS各模块开发及其实现原理. 摘要:Focal Loss的两个性质算是核心,其实就是用一个合适的函数去度量难分类和易分类样本对总的损失 ...
- jquery, jquery-ui, requirejs, bootstrap 的关系理解
jquery 是 基于 javascript 的一个语法衍生,更方便操作dom, 事件,css 整体来说更好用,更简洁. jquery-ui 是基于 jquery 实现的各种更好看,交互更友好的的界面 ...
- Redux/Mobx/Akita/Vuex对比 - 选择更适合低代码场景的状态管理方案
近期准备开发一个数据分析 SDK,定位是作为数据中台向外输出数据分析能力的载体,前端的功能表现类似低代码平台的各种拖拉拽.作为中台能力的载体,SDK 未来很大概率会需要支持多种视图层框架,比如Vue2 ...
- 【转】七个例子帮你更好地理解 CPU 缓存
我的大多数读者都知道缓存是一种快速.小型.存储最近已访问的内存的地方.这个描述相当准确,但是深入处理器缓存如何工作的"枯燥"细节,会对尝试理解程序性能有很大帮助. 在这篇博文中,我 ...
随机推荐
- Windows环境下Mysql如何快速导入或恢复表为innodb的数据
注: 一.这个是对Innodb的数据恢复.MyISAM不需要这么麻烦,只要数据文件存在直接复制过去就可以. 二.该方法只适用于 1:想要恢复或者导入表的ibd文件和frm文件 2:你不仅需有ibd和f ...
- 京东地址导航js+css
HTML------------------------------------------------<!DOCTYPE html><html lang="en" ...
- MYSQL创建数据库时候直接指定编码和排序规则
安装我 在网上搜索的结果执行 代码: sudo gedit /etc/mysql/my.cnf 设置了默认编码为 UTF8 代码: [client]port = 3306sock ...
- Struts2学习笔记(八)——国际化
1.Struts2国际化介绍 国际化即internationalization简称i18n. 为了实现程序的国际化,必须先提供程序所需要的资源文件.资源文件的内容是key-value键值对. 资源文件 ...
- 【2016北京集训测试赛(八)】 crash的数列 (思考题)
Description 题解 题目说这是一个具有神奇特性的数列!这句话是非常有用的因为我们发现,如果套着这个数列的定义再从原数列引出一个新数列,它居然还是一样的...... 于是我们就想到了能不能用多 ...
- APP跨进程数据通信-访问手机联系人
1. 简述 在实际开发中,常常需要进行不同应用程序之间的数据通信,例如读取联系人列表等等,ContentProvider就是Android提供的用于实现不同进程之间进行数据通信的类. ContentP ...
- DataTableToList
很简单的转换功能,这是我在GitHub上复制的一段代码(懒得再去找原地址了),感觉功能还算可以,贴出来分享给大家 /// <summary> /// DataTable to List c ...
- 横排列表(li)的左右对齐
效果如下: HTML代码如下: <div class="overdiv"> <ul> <li>1</li> <li>2& ...
- 模仿Spring实现注解注入
写这个极其蛋疼,我一直在想我们用SSM写项目时,写Service和Controller的时候,会给Service和Controller私有属性,比如Service需要dao,Controller需要S ...
- [转]Java7中的ForkJoin并发框架初探(中)——JDK中实现简要分析
详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp85 根据前文描述的Doug Lea的理论基础,在JDK1.7中已经给 ...