Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >exports 和 module.exports 的区别

exports 和 module.exports 的区别

作者头像
bear_fish
发布于 2018-09-19 08:43:25
发布于 2018-09-19 08:43:25
72500
代码可运行
举报
运行总次数:0
代码可运行

https://cnodejs.org/topic/5231a630101e574521e45ef8

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

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

app.js

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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 结果为:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016年06月29日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
require时,exports和module.exports的区别你真的懂吗?
提到 exports 和 module.exports 我们不得不提到 require 关键字。大家哦读知道 Node.js 遵循 CommonJS 规范,使用 require 关键字来加载模块。
coder_koala
2019/08/19
1.7K0
require时,exports和module.exports的区别你真的懂吗?
exports和module.exports介绍
为了让nodejs开发过程中,为了让Node.js的文件可以相互调用,Node.js提供了一个简单的模块系统,模块是Node.js 应用程序的基本组成部分,文件和模块是一一对应的。换言之,一个 Node.js 文件就是一个模块,这个文件可能是JavaScript 代码、JSON 或者编译过的C/C++ 扩展。
OECOM
2020/07/01
1.6K0
require和import的区别
CommonJs 规范规定,每个模块内部,module变量代表当前模块。这个变量是一个对象,它的 exports属性(即module.exports)是对外的接口,加载某个模块,其实是加载该模块的module.exports属性。
木子星兮
2020/07/16
1.2K0
exports 和 module.exports 的区别
require 用来加载代码,而 exports 和 module.exports 则用来导出代码。但很多新手可能会迷惑于 exports 和 module.exports 的区别,为了更好的理解 exports 和 module.exports 的关系,我们先来巩固下 js 的基础。示例: test.js var a = {name: 1}; var b = a; console.log(a); console.log(b); b.name = 2; console.log(a); console.log
吴裕超
2018/02/28
1.1K0
exports 和 module.exports 的区别
NodeJs-Lesson1-require和module.exports探究
require和module.exports探究 require和module.exports讲解 require exports和module.exports探究 留一个疑问?为什么exports和require都能直接使用,是全局变量吗? require和module.exports讲解 遵守开闭原则:对修改关闭,对扩展开放,所以要想使用引入的模块,子模块必须提供module.exports方法。否则只能运行子模块 require 使用方法 var express = require(“expres
envoke
2020/09/17
5630
NodeJs-Lesson1-require和module.exports探究
NodeJs当中module.exports和exports的区别
Module.exports才是真正的接口,exports只不过是它的一个辅助工具。 最终返回给调用的是Module.exports而不是exports。 所有的exports收集到的属性和方法,都赋值给了Module.exports。当然,这有个前提,就是Module.exports本身不具备任何属性和方法。如果,Module.exports已经具备一些属性和方法,那么exports收集来的信息将被忽略。 如果你想你的模块是一个特定的类型就用Module.exports。如果你想的模块是一个典型的“实例化
苦咖啡
2018/04/28
1.1K0
Node.js Module – exports 和module.exports之间的联系与区别
http://www.hacksparrow.com/node-js-exports-vs-module-exports.html 翻译 相信大家都很熟悉 exports 的用法了,你可以创建一个 function 在你的模块中如下:
蛋未明
2022/05/09
7690
module.exports和exports,应该用哪个
在这篇文章中,我将介绍如何在 Node.js 中使用模块,重点是如何导出和消费它们。
chuckQu
2023/09/12
2380
module.exports和exports,应该用哪个
node.js - 基础之module
为了让node.js的文件可以相互调用,node.js提供了一个简单的模块系统。模块是node.js应用程序基本的组成部分,文件和模块是一一对应的。换言之,一个node.js文件就是一个模块,这个文件可能是javascript代码、json或者编译过的c/c++扩展。
conanma
2022/01/05
9980
前端模块化杂记 前言AMD/CMD简介Commonjs简介Module简介Common和Module的区别Module与webpackModule与Babel一些问题总结引用
前端模块化在近几年层出不穷,有Node的CommonJs,也有属于client端的CMD/AMD模式,而ES6本身也出现了Modules,再加上Webpack以及babel的普及,虽然在代码中经常使用到这些用法,但是如果不去深入研究,总觉得是一个黑魔法,无法探测一些问题的根源。
菜的黑人牙膏
2019/01/28
9010
NodeJS学习二CommonJS规范
Node程序由许多个模块组成,每个模块就是一个文件。Node模块采用了CommonJS规范。
空空云
2018/09/27
6090
Module.exports和exports的区别
学习Seajs时,看到了exports.doSomething和module.exports,想对这两者的区别一探究竟。 [1486958877980_3135_1486958879213.png]
金朝麟
2017/02/11
1.3K0
Module.exports和exports的区别
收藏 | JavaScript 模块全面剖析
前端爱好者的知识盛宴 模块通常是指编程语言所提供的代码组织机制,利用此机制可将程序拆解为独立且通用的代码单元。 所谓模块化主要是解决代码分割、作用域隔离、模块之间的依赖管理以及发布到生产环境时的自动化打包与处理等多个方面。 模块的优点 可维护性。 因为模块是独立的,一个设计良好的模块会让外面的代码对自己的依赖越少越好,这样自己就可以独立去更新和改进。 命名空间。 在 JavaScript 里面,如果一个变量在最顶级的函数之外声明,它就直接变成全局可用。因此,常常不小心出现命名冲突的情况。使用模块化开发来封
用户1097444
2022/06/29
5210
收藏 | JavaScript 模块全面剖析
关于前端开发中的模块化
AngularJS模块化使用的并不是标准的AMD规范,AngularJS的风格风格大致是这样的:
LIYI
2019/09/02
7530
关于前端开发中的模块化
node.js中exports与module.exports的区别
node.js中,每个js文件都可以当成一个模块,每个模块中,都隐含了一个名为module的对象,module对象中有一个exports属性,这个属性的功能是将模块中的变量暴露给其他模块调用。
章鱼喵
2018/08/02
1K0
node.js中exports与module.exports的区别
抖音二面:为什么模块循环依赖不会死循环?CommonJS和ES Module的处理有什么不同?
大家好,我是年年。如果被问到“CommonJS和ES Module的差异”,大概每个前端都都背出几条:一个是导出值的拷贝,一个是导出值的引用;一个是运行时加载,一个是静态编译...
用户9899350
2022/07/29
2K0
抖音二面:为什么模块循环依赖不会死循环?CommonJS和ES Module的处理有什么不同?
前端模块化-CommonJS,AMD,CMD,ES6
随着 JavaScript 工程越来越大,团队协作不可避免,为了更好地对代码进行管理和测试,模块化的概念逐渐引入前端。模块化可以降低协同开发的成本,减少代码量,同时也是“高内聚,低耦合”的基础。
李振
2021/11/26
4240
深入学习 Node.js Module
Node.js 遵循 CommonJS规范,该规范的核心思想是允许模块通过 require 方法来同步加载所要依赖的其他模块,然后通过 exports 或 module.exports 来导出需要暴露的接口。CommonJS 规范是为了解决 JavaScript 的作用域问题而定义的模块形式,可以使每个模块它自身的命名空间中执行。
阿宝哥
2019/11/06
1.1K0
深入学习 Node.js Module
一文彻底搞懂ES6 Module
模块,(Module),是能够单独命名并独立地完成一定功能的程序语句的集合(即程序代码和数据结构的集合体)。
@超人
2021/07/29
4880
一文彻底搞懂ES6 Module
JavaScript从初级往高级走系列————ES6
在nodejs,exports 是 module.exports的引用,初始化时,它们都指向同一个{}对象。
FinGet
2019/06/28
6760
相关推荐
require时,exports和module.exports的区别你真的懂吗?
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验