exports 和 module.exports 的区别

我理解的exports 和 module.exports 的区别,欢迎大家吐槽~

为了更好的理解 exportsmodule.exports 的关系,我们先来补点 js 基础。示例:

app.js

var a = {name: ‘nswbmw 1‘};
var b = a;

console.log(a);
console.log(b);

b.name = ‘nswbmw 2‘;
console.log(a);
console.log(b);

var b = {name: ‘nswbmw 3‘};
console.log(a);
console.log(b);

运行 app.js 结果为:

D:\>node app
{ name: ‘nswbmw 1‘ }
{ name: ‘nswbmw 1‘ }
{ name: ‘nswbmw 2‘ }
{ name: ‘nswbmw 2‘ }
{ name: ‘nswbmw 2‘ }
{ name: ‘nswbmw 3‘ }

D:\>

解释一下:a 是一个对象,b 是对 a 的引用,即 a 和 b 指向同一个对象,即 a 和 b 指向同一块内存地址,所以前两个输出一样。当对 b 作修改时,即 a 和 b 指向同一块内存地址的内容发生了改变,所以 a 也会体现出来,所以第三四个输出一样。当对 b 完全覆盖时,b 就指向了一块新的内存地址(并没有对原先的内存块作修改),a 还是指向原来的内存块,即 a 和 b 不再指向同一块内存,也就是说此时 a 和 b 已毫无关系,所以最后两个输出不一样。

明白了上述例子后,我们进入正题。 我们只需知道三点即可知道 exportsmodule.exports 的区别了:

1 exports 是指向的 module.exports 的引用
2 module.exports 初始值为一个空对象 {},所以 exports 初始值也是 {}
3 require() 返回的是 module.exports 而不是 exports

所以:

  • 我们通过
var name = ‘nswbmw‘;
  exports.name = name;
  exports.sayName = function() {
    console.log(name);
  }

exports 赋值其实是给 module.exports 这个空对象添加了两个属性而已,上面的代码相当于:

 var name = ‘nswbmw‘;
  module.exports.name = name;
  module.exports.sayName = function() {
    console.log(name);
  }

我们通常这样使用 exportsmodule.exports

一个简单的例子,计算圆的面积:

使用 exports

app.js

var circle = require(‘./circle‘);
  console.log(circle.area(4));

circle.js

exports.area = function(r) {
    return r * r * Math.PI;
  }

使用 module.exports

app.js

var area = require(‘./area‘);
  console.log(area(4));

area.js

module.exports = function(r) {
    return r * r * Math.PI;
  }

上面两个例子输出是一样的。你也许会问,为什么不这样写呢?

app.js

 var area = require(‘./area‘);
  console.log(area(4));

area.js

 exports = function(r) {
    return r * r * Math.PI;
  }

运行上面的例子会报错。这是因为,前面的例子中通过给 exports 添加属性,只是对 exports 指向的内存做了修改,而

exports = function(r) {
    return r * r * Math.PI;
  }

其实是对 exports 进行了覆盖,也就是说 exports 指向了一块新的内存(内容为一个计算圆面积的函数),也就是说 exportsmodule.exports 不再指向同一块内存,也就是说此时 exportsmodule.exports 毫无联系,也就是说 module.exports 指向的那块内存并没有做任何改变,仍然为一个空对象 {} ,也就是说 area.js 导出了一个空对象,所以我们在 app.js 中调用 area(4) 会报 TypeError: object is not a function 的错误。

所以,一句话做个总结:当我们想让模块导出的是一个对象时, exportsmodule.exports 均可使用(但 exports 也不能重新覆盖为一个新的对象),而当我们想导出非对象接口时,就必须也只能覆盖 module.exports

我们经常看到这样的用写法:

exports = module.exports = somethings

上面的代码等价于

 module.exports = somethings
  exports = module.exports

原因也很简单, module.exports = somethings 是对 module.exports 进行了覆盖,此时 module.exportsexports 的关系断裂,module.exports 指向了新的内存块,而 exports 还是指向原来的内存块,为了让 module.exportsexports 还是指向同一块内存或者说指向同一个 “对象”,所以我们就 exports = module.exports

时间: 2024-12-24 05:58:40

exports 和 module.exports 的区别的相关文章

node.js 的 exports 和 module.exports 的区别

commonjs node.js 的模块系统就是按照模块化规范 commonjs 来实现的: var math = require("math"); math.add(1, 2); exports 和 module.exports node.js 实现模块化最常用的函数就是 exports 和 module.exports. exports 是指向 module.exports 的引用.它们初始化都是为{},require() 返回的是 module.exports,所以当改变了 mo

exports和module.exports的区别

最近忍不住开始尝试nodeJS了,简直又是打开了一片天地,学的越多越觉得自己好low,还有好多好多东西没有触碰,没有学习. 解决这个问题的唯一的办法就是卧薪尝胆. 好的,刚开始接触nodeJS,在视频学习的时候看到了exports和module.exports这两种导出模块函数的方法.哎,好老师太难遇到了,我唯一喜欢的老师就是带我坑js的石川老师,其他老师的视频我实在不知道说什么好.好吧又说别的了,其实我的意思是我没有听懂exports和module.exports的区别,而且那个老师也只是随便

nodejs模块中exports和module.exports的区别

通过Node.js的官方API可以看到Node.js本身提供了很多核心模块 http://nodejs.org/api/ ,这些核心模块被编译成二进制文件,可以require('模块名')去获取:核心模块具有最高的加载优先级(有模块与核心模块同名时会体现) 文件模块访问方式通过require('/文件名.后缀') require('./文件名.后缀') requrie('../文件名.后缀') 去访问,文件后缀可以省略:以"/"开头是以绝对路径去加载,以"./"开头

nodejs exports与module.exports的区别

exports和module.exports的作用都是将文件模板的方法和属性暴露给require返回的对象进行调用.但是两者有本质的区别,exports的属性和方法都可以被module.exports替代. 如下代码是一样的: exports.name='iwang' module.exports.name = 'iwang' 但是exports不能替代module.exports的方法,所有的exports对象最终都是通过module.exports传递执行的.可以理解exports是给mod

node exports和module.exports区别

我们只需知道三点即可知道 exports 和 module.exports 的区别了: exports 是指向的 module.exports 的引用 module.exports 初始值为一个空对象 {},所以 exports 初始值也是 {} require() 返回的是 module.exports 而不是 exports 所以: 我们通过 var name ='nswbmw'; exports.name = name; exports.sayName =function(){ conso

node.js module初步理解,exports与module.exports的区别

在开发一个复杂的应用程序的时候,我们需要把各个功能拆分.封装到不同的文件,在需要的时候引用该文件.没人会写一个几万行代码的文件,这样在可读性.复用性和维护性上都很差,几乎所有的编程语言都有自己的模块组织方式,比如Java中的包.C#中的程序集等,node.js使用模块和包来组织,其机制实现参照了CommonJS标准,虽未完全遵守,但差距不大,使用起来非常简单. 在node.js中模块与文件是一一对应的,也就是说一个node.js文件就是一个模块,文件内容可能是我们封装好的一些JavaScript

exports与module.exports的区别,export与export.defult区别

在JS模块化编程中,之前使用的是require.js或者sea.js.随着前端工程化工具webpack的推出,使得前端js可以使用CommonJS模块标准或者使用ES6 moduel特性. 在CommonJs模块标准中我们载入模块使用的是require(),输出模块用的是exports或者module.exports 在ES6中载入模块我们用的是import ,输出模块用的是export exports与module.exports的区别 //载入模块 var m = require('./mo

nodejs中exports与module.exports的区别

node中exports模块对象相信大家一定不陌生: 如studentModule.js: exports.student = function() { console.log("this is student module!"); } 在另一个模块中这样引用: var student = require('./studentModule.js'); student.student(); // this is student module! 那么问题来了:module.exports是

Node.js中exports与module.exports的区别

原文:http://www.hacksparrow.com/node-js-exports-vs-module-exports.html 你肯定对Node.js模块中用来创建函数的exports对象很熟悉(假设一个名为rocker.js的文件): exports.name = function() { console.log('My name is Lemmy Kilmister'); }; 然后你在另一个文件中调用: var rocker = require('./rocker.js'); r