module.exports与exports的区别
来源:互联网 发布:手机诊断软件超级兔子 编辑:程序博客网 时间:2024/06/01 10:44
转载自:http://cnodejs.org/topic/52308842101e574521c16e06
module.exports与exports的区别
每一个node.js执行文件,都自动创建一个module对象,同时,module对象会创建一个叫exports的属性,初始化的值是 {}
module.exports = {};
Node.js为了方便地导出功能函数,node.js会自动地实现以下这个语句
foo.js
exports.a = function(){
console.log(‘a’)
}
exports.a = 1
test.js
var x = require(‘./foo’);
console.log(x.a)
看到这里,相信大家都看到答案了,exports是引用 module.exports的值。module.exports 被改变的时候,exports不会被改变,而模块导出的时候,真正导出的执行是module.exports,而不是exports
再看看下面例子
foo.js
exports.a = function(){
console.log(‘a’)
}
module.exports = {a: 2}
exports.a = 1
test.js
var x = require(‘./foo’);
console.log(x.a)
result:
2
exports在module.exports 被改变后,失效。
是不是开始有点廓然开朗,下面将会列出开源模块中,经常看到的几个使用方式。
module.exports = View
function View(name, options) {
options = options || {};
this.name = name;
this.root = options.root;
var engines = options.engines;
this.defaultEngine = options.defaultEngine;
var ext = this.ext = extname(name);
if (!ext && !this.defaultEngine) throw new Error(‘No default engine was specified and no extension was provided.’);
if (!ext) name += (ext = this.ext = (‘.’ != this.defaultEngine[0] ? ‘.’ : ”) + this.defaultEngine);
this.engine = engines[ext] || (engines[ext] = require(ext.slice(1)).__express);
this.path = this.lookup(name);
}
module.exports = View;
javascript里面有一句话,函数即对象,View 是对象,module.export =View, 即相当于导出整个view对象。外面模块调用它的时候,能够调用View的所有方法。不过需要注意,只有是View的静态方法的时候,才能够被调用,prototype创建的方法,则属于View的私有方法。
foo.js
function View(){
}
View.prototype.test = function(){
console.log(‘test’)
}
View.test1 = function(){
console.log(‘test1’)
}
module.exports = View
test.js
var x = require(‘./foo’);
console.log(x) //{ [Function: View] test1: [Function] }
console.log(x.test) //undefined
console.log(x.test1) //[Function]
x.test1() //test1
var app = exports = module.exports = {};
其实,当我们了解到原理后,不难明白这样的写法有点冗余,其实是为了保证,模块的初始化环境是干净的。同时也方便我们,即使改变了 module.exports 指向的对象后,依然能沿用 exports的特性
exports = module.exports = createApplication;
/**
* Expose mime.
*/
exports.mime = connect.mime;
例子,当中module.exports = createApplication改变了module.exports了,让exports失效,通过exports = module.exports的方法,让其恢复原来的特点。
exports.init= function(){}
这种最简单,直接就是导出模块 init的方法。
var mongoose = module.exports = exports = new Mongoose;
- module.exports与exports的区别
- module.exports 与 exports的区别
- exports与module.exports的区别
- module.exports与exports的区别
- NodeJS中module.exports与exports的区别
- nodejs中exports与module.exports的区别详细介绍
- nodejs中exports与module.exports的区别
- Node.js中exports与module.exports的区别
- nodejs中exports与module.exports的区别
- nodejs中exports与module.exports的区别
- nodejs中exports与module.exports的区别详细介绍
- nodejs中exports与module.exports的区别
- nodejs中exports与module.exports的区别详细介绍
- Node.js中module.exports与exports的区别
- nodejs中exports与module.exports的区别详细介绍
- 前端学习之路:exports 与module.exports的区别
- nodejs中exports与module.exports的区别
- nodejs中exports与module.exports的区别
- 面向对象
- Word Ladder
- PS软件常用快捷键
- Python学习日记 第九天 EX20-21
- 根据传入的时间,自动计算规则时间(如:包期时段的开始时间和结束时间)
- module.exports与exports的区别
- 中断响应流水灯控制程序
- 资料整理(目录)
- SparkMLlib---基于余弦相似度的用户相似计算
- ES6 Class继承中super在不同场景中的用法
- Oracle的Index,以及组合Index
- Tomcat优化详解
- 上传代码到GitLab
- Linux中利用子进程实现多个客户端和服务器端通信