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是给module.exports添加属性和方法的。一开始module.exports是一个空对象。我们使用 require()返回的对象就是module.exports对象。

  文件模板module.js 其实什么都没有写单纯打印module.exports

console.log(module.exports)

调用文件模板index.js

var obj = require(‘/module‘)
console.log(obj)  // {}

打印出的就是没有属性和方法的空对象。

看下面文件代码

module.exports = {
    name:‘iwang‘,
    age:26
}
exports.stature = 180
console.log(module.exports) // { name: ‘iwang‘, age: 26 }

我们对module.exports 重新定义了这个对象。而不是对module.exportst添加属性和方法。这样做,打断了module.exports和exports的关系。我们使用exports.stature添加了一个stature(身高)的属性,并不管用。当我们使用下面做法,就没有问题。

module.exports.name = ‘iwang‘;
module.exports.age = 26;
exports.stature = 180;
console.log(module.exports) // { name: ‘iwang‘, age: 26, stature: 180 }

所以 我们可以理解 一开始 moudle.exports = exports = {},使用require返回的对象是module.exports。所以当我们重新定义module.exports为其他对象的指针。exports和module.exports再也没有半毛钱关系。

只要大家上面理解红色文字的话,就能区别module.exports和exports的关系了。

时间: 2024-08-07 05:06:00

nodejs exports与module.exports的区别的相关文章

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

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

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是

nodeJS exports – exports vs module.exports

require, exports, module.exports 区别: require 用来加载代码(模块),而 exports 和 module.exports 则用来导出代码. exports 是指向的 module.exports 的引用 module.exports 初始值为一个空对象 {},所以 exports 初始值也是 {} require() 返回的是 module.exports 而不是 exports nodejs中exports与module.exports的区别: Mo

exports和module.exports的区别

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

深入理解nodejs 中 exports与module.exports

在Javascript 中,有2种作用域,分为 全局作用域 ,和函数作用域, 在 浏览器端 , 全局作用域 就是 window对象的属性, 函数作用域 就是 ,某个 函数 生成的对象的属性: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <script> var name

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

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

exports 和 module.exports 的区别

我理解的exports 和 module.exports 的区别,欢迎大家吐槽~ 为了更好的理解 exports 和 module.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

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

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