CommonJS根据JS的表现制定规范:
{模块引用(require)} {模块定义(exports)} {模块标识(module)}
NodeJS遵循了CommonJS规范,写法如下:
// foo.js
module.exports = function(x) {
console.log(x);
};
// index.js
let foo = require('./foo')
foo(1);
CommonJS主要为了JS在后端制定的规范,但并不适用与前端,因为代码在是通过网络加载,所以AMD(异步模块定义)出现:
define(['dep1','dep2'],function(dep1,dep2){...});
RequireJS实现了AMD规范,写法如下:
// foo.js
define(function() {
return function(x) {
console.log(x);
};
});
// index.js
define(['foo'], function(foo) {
foo(2);
});
CMD (通用模块定义)写法更加直观:
// 所有模块都通过 define 来定义 define(function(require, exports, module) {
// 通过 require 引入依赖 var $ = require('jquery'); var Spinning = require('./spinning');
// 通过 exports 对外提供接口 exports.doSomething = ...
// 或者通过 module.exports 提供整个接口 module.exports = ... });
// foo.js
define(function(require, exports, module) {
module.exports = function(x) {
console.log(x);
}
});
// index.js
define(function(require, exports, module) {
var foo = require('foo');
foo(3);
});