// 支持AMD,CMD以及原生js的引用
if (typeof module !== 'undefined' && typeof exports === 'object' && define.cmd) {
module.exports = SB;
} else if (typeof define === 'function' && define.amd) {
define(function() {
return SB;
});
} else {
this.SB= SB;
}
}).call(function() {
return this || (typeof window !== 'undefined' ? window : global);
}
复制代码
//作的工做其实就是这么粗暴,判断当前用的什么就以当前规范来定义
(function (root, factory) {
if (typeof define === 'function' && define.amd) {
// AMD
define(['jquery'], factory);
} else if (typeof exports === 'object') {
// CommonJS
module.exports = factory(require('jquery'));
} else {
// 全局变量
root.returnExports = factory(root.jQuery);
}
}(this, function ($) {
// methods
function myFunc(){};
// exposed public method
return myFunc;
}));
复制代码
UMD:
Universal Module Definition 通用模块规范。
基于统一规范的目的出现,看起来没那么简约,可是支持amd和commonjs以及全局模块模式。前端
//作的工做其实就是这么粗暴,判断当前用的什么就以当前规范来定义
(function (root, factory) {
if (typeof define === 'function' && define.amd) {
// AMD
define(['jquery'], factory);
} else if (typeof exports === 'object') {
// CommonJS
module.exports = factory(require('jquery'));
} else {
// 全局变量
root.returnExports = factory(root.jQuery);
}
}(this, function ($) {
// methods
function myFunc(){};
// exposed public method
return myFunc;
}));复制代码
如今的前端模块化标准主要有两种, CMD
, AMD
。jquery
CMDbash
CMD
在模块定义当中有三个变量,分别是 require
, exports
, module
。除了这三个变量能够辨识 CMD
外, define
函数还有一个公有属性 define.cmd
。咱们也能够检测这个值来判断是不是 CMD
。模块化
若是想要对外提供接口的话,能够将接口绑定到 exports
(即 module.exports
) 上。函数
function MyModule() {
// ...
}
if(typeof module !== `undefined` && typeof exports === `object` && define.cmd) {
module.exports = MyModule;
}
复制代码
若是须要支持除了 CMD
以外的其余符合 CommonJS
的标准,请去掉 define.cmd
ui
AMDthis
AMD
规范中, define
函数一样有一个公有属性 define.amd
。spa
AMD
中的参数即是这个模块的依赖。那么如何在 AMD
中提供接口呢?它是返回一个对象,这个对象就做为这个模块的接口,故咱们能够这样写:插件
function MyModule() {
// ...
}
if(typeof define === `function` && define.amd) {
define(function() { return MyModule; });
}
复制代码
咱们除了提供 AMD
模块接口, CMD
模块接口,还得提供原生的 JS 接口,一个直接能够用的代码以下:code
;(function(){
function MyModule() {
// ...
}
var moduleName = MyModule;
if (typeof module !== 'undefined' && typeof exports === 'object' && define.cmd) {
module.exports = moduleName;
} else if (typeof define === 'function' && define.amd) {
define(function() { return moduleName; });
} else {
this.moduleName = moduleName;
}
}).call(function() {
return this || (typeof window !== 'undefined' ? window : global);
});
复制代码
通常插件的作法:
if (typeof module != 'undefined' && module.exports) { //CMD
module.exports = SB;
} else if (typeof define == 'function' && define.amd) { //AMD
define(function() {
return SB;
});
} else { //no AMD or CMD
window.SB= SB;
}复制代码