require 用来加载代码,而 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'};
console.log(a);
console.log(b);
运行 app.js 结果为:
{ name: 'nswbmw 1' }
{ name: 'nswbmw 1' }
{ name: 'nswbmw 2' }
{ name: 'nswbmw 2' }
{ name: 'nswbmw 2' }
{ name: 'nswbmw 3' }
解释一下:a 是一个对象,b 是对 a 的引用,即 a 和 b 指向同一个对象,即 a 和 b 指向同一块内存地址,所以前两个输出一样。当对 b 作修改时,即 a 和 b 指向同一块内存地址的内容发生了改变,所以 a 也会体现出来,所以第三、四个输出一样。当对 b 完全覆盖时,b 就指向了一块新的内存地址(并没有对原先的内存块作修改),a 还是指向原来的内存块,即 a 和 b 不再指向同一块内存,也就是说此时 a 和 b 已毫无关系,所以最后两个输出不一样。
明白了上述例子后,我们进入正题。
我们只需知道三点即可知道 exports 和 module.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);
}
我们通常这样使用 exports 和 module.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 指向了一块新的内存(内容为一个计算圆面积的函数),也就是说 exports 和 module.exports 不再指向同一块内存,也就是说此时 exports 和 module.exports 毫无联系,也就是说 module.exports 指向的那块内存并没有做任何改变,仍然为一个空对象 {} ,也就是说 area.js 导出了一个空对象,所以我们在 app.js 中调用 area(4) 会报 TypeError: object is not a function 的错误。
所以,一句话做个总结:当我们想让模块导出的是一个对象时,exports 和 module.exports 均可使用(但 exports也不能重新覆盖为一个新的对象),而当我们想导出非对象接口时,就必须也只能覆盖 module.exports。
我们经常看到这样的用写法:
exports = module.exports = somethings;
上面的代码等价于
module.exports = somethings; exports = module.exports;
原因也很简单,module.exports = somethings 是对 module.exports 进行了覆盖,此时 module.exports 和 exports 的关系断裂,module.exports 指向了新的内存块,而 exports 还是指向原来的内存块,为了让 module.exports 和 exports 还是指向同一块内存或者说指向同一个 “对象”,所以我们就 exports = module.exports。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# exports
# module.exports
# 详解Js模块化的作用原理和方案
# node.js核心模块有哪些
# js实现简单购物车模块
# Node.js之http模块的用法
# 详解Sea.js中Module.exports和exports的区别
# node.js中module.exports与exports用法上的区别
# nodejs中exports与module.exports的区别详细介绍
# javascript高级模块化require.js的具体使用方法
# 详解RequireJs官方使用教程
# Js模块打包exports require import的用法和区别
# 也就是说
# 的是
# 会报
# 进行了
# 是一个
# 也会
# 只需
# 也很
# 做个
# 均可
# 当我们
# 三点
# 想让
# 或者说
# 句话
# 报错
# 也许会
# 这是因为
# 那块
# 先来
相关文章:
网站代码制作软件有哪些,如何生成自己网站的代码?
如何通过可视化优化提升建站效果?
微信推文制作网站有哪些,怎么做微信推文,急?
如何通过虚拟主机快速搭建个人网站?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
金*站制作公司有哪些,金华教育集团官网?
建站之星后台管理系统如何操作?
已有域名如何快速搭建专属网站?
电商网站制作价格怎么算,网上拍卖流程以及规则?
建站之星ASP如何实现CMS高效搭建与安全管理?
c# F# 的 MailboxProcessor 和 C# 的 Actor 模型
长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?
如何配置WinSCP新建站点的密钥验证步骤?
如何通过主机屋免费建站教程十分钟搭建网站?
网站专业制作公司有哪些,做一个公司网站要多少钱?
如何正确选择百度移动适配建站域名?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
为什么Go需要go mod文件_Go go mod文件作用说明
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
建站之星如何助力网站排名飙升?揭秘高效技巧
在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?
html制作网站的步骤有哪些,iapp如何添加网页?
无锡营销型网站制作公司,无锡网选车牌流程?
图册素材网站设计制作软件,图册的导出方式有几种?
制作门户网站的参考文献在哪,小说网站怎么建立?
如何在自有机房高效搭建专业网站?
建站之星在线版空间:自助建站+智能模板一键生成方案
网站制作费用多少钱,一个网站的运营,需要哪些费用?
如何快速生成高效建站系统源代码?
如何在Golang中处理模块冲突_解决依赖版本不兼容问题
如何挑选优质建站一级代理提升网站排名?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
如何在Tomcat中配置并部署网站项目?
小程序网站制作需要准备什么资料,如何制作小程序?
网站企业制作流程,用什么语言做企业网站比较好?
专业网站建设制作报价,网页设计制作要考什么证?
宝塔面板创建网站无法访问?如何快速排查修复?
焦点电影公司作品,电影焦点结局是什么?
如何配置支付宝与微信支付功能?
如何在景安云服务器上绑定域名并配置虚拟主机?
建站之星备案流程有哪些注意事项?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
宁波免费建站如何选择可靠模板与平台?
制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?
高性价比服务器租赁——企业级配置与24小时运维服务
建站之星安装失败:服务器环境不兼容?
全景视频制作网站有哪些,全景图怎么做成网页?
零基础网站服务器架设实战:轻量应用与域名解析配置指南
如何解决VPS建站LNMP环境配置常见问题?
*请认真填写需求信息,我们会在24小时内与您取得联系。