前言 - 什么是 CMD 模式
CMD是 1
| Common Module Definition |
的缩写,意思就是
。
CMD 模式的 需要载入
这个包, 浏览器兼容ie5.5+ 所以放心用吧。
下载地址 http://seajs.org/
模块定义方式:
1
2
3
| define("ID",["依赖模块"],function (require, exports, module) {
});
|
ID 当前模块的唯一
[“…”] 依赖模块
require 用来载入其它模块
exports 导出方法
module 导出模块
简单模块调用
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
| // 单例模式
define(function(require, exports, module) {
console.log("module1 被装载~");
exports.num = 10;
exports.add = function(){
this.num ++;
};
exports.get = function(){
return this.num;
};
});
|
通过 exports 导出了2个方法 add get,一个属性 num。
方法中访问成员变量 this.num 方式。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
| <script src="../sea-modules/core/sea.js" id="seajsnode" ></script>
<script>
seajs.config({
base: "../sea-modules/",
});
seajs.use(['lib/module1'],function(mod1){
mod1.add();
mod1.add();
console.log(mod1.get());
});
seajs.use(['lib/module1'],function(mod1){
mod1.add();
mod1.add();
console.log(mod1.get());
});
</script>
|
导入sea.js包
定义seajs.config 的 base 代码根目录
seajs.use方式 使用 module1
连续调用了两次
module1 被装载~
12
14
我们可以发现这是单例模式,作用域是整个页面,所以num是累加了。
非单例模式
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
| // 非单例模式
define(function(require, exports, module) {
console.log("module2 被装载~");
function UserModel() {
var num = 1000;
var name = "AAAAA";
var uid = "1001";
this.add = function () {
num ++;
};
this.show = function () {
return num + ":" + name + ":" + uid;
};
}
module.exports = function () {
return new UserModel();
};
});
|
模型方式导出 module.exports
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
| <script src="../sea-modules/core/sea.js" id="seajsnode" ></script>
<script>
seajs.config({
base: "../sea-modules/",
});
seajs.use(['lib/module2'],function(mod2){
var mod = new mod2();
mod.add();
mod.add();
mod.add();
console.log(mod.show());
});
seajs.use(['lib/module2'],function(mod2){
var mod = new mod2();
mod.add();
mod.add();
mod.add();
console.log(mod.show());
});
</script>
|
seajs.use 调用后 是一个 function()
我们用 new 的方式实例一个新对象
这里也是重复调用两次
module2 被装载~
1003:AAAAA:1001
1003:AAAAA:1001
可以发现这次是非单例了,每次都是新的对象,互不影响。
模块依赖
1
2
3
4
5
6
7
8
9
10
| // 模块依赖
define(['module1'],function(require, exports, module) {
console.log("module3 被装载~");
var mod1 = require('module1');
mod1.add();
console.log("module1 执行完成");
});
|
依赖模块 module1
require装载 module1 ,并执行 add 操作
1
2
3
4
5
6
7
8
9
10
11
12
13
14
| <script src="../sea-modules/core/sea.js" id="seajsnode" ></script>
<script>
seajs.config({
base: "../sea-modules/",
alias: {
"module1": "lib/module1.js"
}
});
seajs.use(['lib/module3'],function(mod3){
console.log("module3 执行完成");
});
</script>
|
seajs.config alias 设置别名 module1
module3 被装载~
module1 被装载~
module1 执行完成
module3 执行完成
可以发现 CMD 果然是顺序执行,模块是懒加载,在需要的时候加载,不会像AMD方式先加载模块。
下载操作,是在执行定义依赖
时浏览器客户端开始下载。
异步方式加载
1
2
3
4
5
6
7
| define(function(require) {
require.async('module1', function(mod1) {
mod1.add();
});
});
|
异步加载一个模块,在加载完成时,执行回调
模块化第三方代码 jquery
规范了模块的定义虽然好,但是用第三非CMD定义模块时,就有点麻烦了,比如这个jquery,你直接 require 直接返回
。
1
2
3
4
5
6
7
8
| define(function () {
// jquery代码
...
// 加入return
return $.noConflict();
});
|
用一个
包裹下
最后
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
| define("lib/module4", ["./module4-ui"], function(require) {
var ui = require("./module4-ui");
ui.setup();
});
define("lib/module4-ui", ["jquery"], function(require, exports, module) {
var $ = require("jquery");
exports.setup = function () {
$("#myButton").click( function () {
alert(123);
});
};
});
|
我把UI处理单独出来了,设置模块ID
1
| var $ = require("jquery"); |
方式载入jquery模块 测试一个按钮事件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
| <script src="../sea-modules/core/sea.js" ></script>
<script>
seajs.config({
base: "../sea-modules/",
alias: {
"jquery": "core/jquery-3.1.1.seajs.min.js"
}
});
seajs.use("lib/module4");
</script>
<button id="myButton">点击我</button>
|
用
配置了别名 模块中可以直接使用
放置了一个按钮
触发成功
模块化 调用jquery插件
同样你要用相关依赖jquery的插件,也需要修改相关代码。
我这里修改了一个确认对话框插件 artDialog
1
2
3
4
5
6
7
8
9
10
| define("lib/artDialog/dialog", ["jquery"], function (require, exports, module) {
var jQuery = require("jquery");
// 放置原来的插件代码
module.exports = function (options, ok, cancel) {
return new dialog(options, ok, cancel);
};
});
|
首先包一个
定义
然后创建依赖需要的 1
| var jQuery = require("jquery"); |
对象
最后导出定义模块定义 1
| module.exports = function ... |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
| define("lib/module4", ["./module4-ui"], function(require) {
var ui = require("./module4-ui");
ui.setup();
});
define("lib/module4-ui", ["jquery","dialog"], function(require, exports, module) {
var $ = require("jquery");
var dialog = require("dialog");
exports.setup = function () {
$("#myButton").click( function () {
var d = dialog({
title: '欢迎',
content: '欢迎使用 artDialog 对话框组件!'
});
d.showModal();
});
};
});
|
读取调用 1
| var dialog = require("dialog"); |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
| <script src="../sea-modules/core/sea.js" ></script>
<script src="../sea-modules/core/seajs-css.js" ></script>
<script>
seajs.config({
base: "../sea-modules/",
alias: {
"jquery": "core/jquery-3.1.1.seajs.min.js",
"dialog": "lib/artDialog/dialog.js"
}
});
seajs.use("lib/artDialog/ui-dialog.css");
seajs.use("lib/module4");
</script>
<button id="myButton">点击我</button>
|
加入alias别名
这里用了一个
的插件动态读取了css
插件地址 https://github.com/seajs/seajs-css/blob/master/README.md
弹出成功!
参考代码
https://github.com/hans007/JavaScriptCodes/tree/master/seajs%E6%A8%A1%E5%9D%97%E5%8C%96/app
我的博客
Read More