CommonJS规范
2013-11-26 17:23
309 查看
目录
概述AMD规范与CommonJS规范的兼容性
参考链接
概述
CommonJS是服务器端模块的规范,Node.js采用了这个规范。根据CommonJS规范,一个单独的文件就是一个模块。加载模块使用require方法,该方法读取一个文件并执行,最后返回文件内部的exports对象。下面就是一个简单的模块文件example.js。
console.log("evaluating example.js"); var invisible = function () { console.log("invisible"); } exports.message = "hi"; exports.say = function () { console.log(message); }
使用require方法,加载example.js。
var example = require('./example.js');
这时,变量example就对应模块中的exports对象,于是就可以通过这个变量,使用模块提供的各个方法。
{ message: "hi", say: [Function] }
require方法默认读取js文件,所以可以省略js后缀名。
var example = require('./example');
js文件名前面需要加上路径,可以是相对路径(相对于使用require方法的文件),也可以是绝对路径。如果省略路径,node.js会认为,你要加载一个核心模块,或者已经安装在本地 node_modules 目录中的模块。如果加载的是一个目录,node.js会首先寻找该目录中的 package.json 文件,加载该文件 main 属性提到的模块,否则就寻找该目录下的 index.js 文件。
下面的例子是使用一行语句,定义一个最简单的模块。
// addition.js exports.do = function(a, b){ return a + b };
上面的语句定义了一个加法模块,做法就是在exports对象上定义一个do方法,那就是供外部调用的方法。使用的时候,只要用require函数调用即可。
var add = require('./addition'); add.do(1,2) // 3
再看一个复杂一点的例子。
// foobar.js function foobar(){ this.foo = function(){ console.log('Hello foo'); } this.bar = function(){ console.log('Hello bar'); } } exports.foobar = foobar;
调用该模块的方法如下:
var foobar = require('./foobar').foobar, test = new foobar(); test.bar(); // 'Hello bar'
有时,不需要exports返回一个对象,只需要它返回一个函数。这时,就要写成module.exports。
module.exports = function () { console.log("hello world") }
AMD规范与CommonJS规范的兼容性
CommonJS规范加载模块是同步的,也就是说,只有加载完成,才能执行后面的操作。AMD规范则是非同步加载模块,允许指定回调函数。由于Node.js主要用于服务器编程,模块文件一般都已经存在于本地硬盘,所以加载起来比较快,不用考虑非同步加载的方式,所以CommonJS规范比较适用。但是,如果是浏览器环境,要从服务器端加载模块,这时就必须采用非同步模式,因此浏览器端一般采用AMD规范。AMD规范使用define方法定义模块,下面就是一个例子:
define(['package/lib'], function(lib){ function foo(){ lib.log('hello world!'); } return { foo: foo }; });
AMD规范允许输出的模块兼容CommonJS规范,这时define方法需要写成下面这样:
define(function( require, exports, module ) var someModule = require( "someModule" ); var anotherModule = require( "anotherModule" ); someModule.doTehAwesome(); anotherModule.doMoarAwesome(); exports.asplode = function() { someModule.doTehAwesome(); anotherModule.doMoarAwesome(); }; });
参考链接
Addy Osmani, Writing Modular JavaScript With AMD, CommonJS & ES Harmony本文转自:http://javascript.ruanyifeng.com/nodejs/commonjs.html
相关文章推荐
- 应用js改变问章字体大小
- 使用$.getJSON实现跨域ajax请求示例代码
- SetTimeOut()和ClearTimeout()
- JS动态生成元素鼠标响应方法 .live()
- JavaScript实现本地图片上传预览功能(兼容IE、chrome、FF)
- json格式
- 点滴积累【JS】---JS小功能(setInterval实现图片效果显示时间)
- cs3属性操作js
- javascript获取页面宽度高度及屏幕分辨率
- javascripts中confirm(),prompt()方法及其使用方法
- 后台返回一个string类型的json格式数据,前台js如何读取?
- 当鼠标滑过文本框自动选中输入框内容的JS代码分享
- Extjs4中form表单提交后无法进入success函数的问题
- 学习Javascript闭包(Closure)
- 怎样用javascript返回上一页
- JS代码判断浏览器版本,支持IE6,IE7,IE8,IE9!三种方法!
- javascript的select 输入匹配
- Jboss运行JSP报各种编译错误 statements are only available if source level is 5.0
- js输出数字用千分号分隔的三种方法
- js中animate的应用