详解Node.js中exports和module.exports的区别


Posted in Javascript onApril 19, 2017

今天看了下node.js的require方法的源码,终于搞清楚exports和module.exports的区别了。

我们知道,node.js的模块暴露有两种方法。

1. 方式一:用exports

//a.js

 exports.log =function (str) {
  console.log(str);
}
//b.js

 var s = require("./a");
 s.log("哈哈哈哈");

2. 方式二:用module.exports

//a.js
 module.exports = function (str) {
    console.log(str);
 }

//b.js
 var s = require("./a");
 s("嘻嘻嘻嘻");

如果将第一种方式的exports按照第二种方式写成下面这样就会出错:

//a.js
 exports = function (str) {
  console.log(str);
}
//b.js

 var s = require("./a");
 s("哈哈哈哈");

exportsmodule.exports的初始值指向的是空对象,即{}。从源码可以看到,其实模块的require方法实质上是调用了_load方法,而_load方法,最终返回的是module.exports

详解Node.js中exports和module.exports的区别

详解Node.js中exports和module.exports的区别 

来分析一下出错的原因。

由于最开始的时候,exportsmodule.exports都指向同一个对象。

第一种方式,是在给这个空对象{}添加属性,又因为module.exports也是指向这个对象的,所以最终require方法返回的module.exports是指向了这个具有log方法的对象的,可以引用到模块。

第二种方式是让module.exports指向一片新的内存空间,exports指向的仍然是{},但是由于require方法返回的是module.exports,所以最终也能引入模块。

但是最后那种写法是让exports指向一片新的内存空间,module.exports指向的仍然还是{},那么最终require方法是将module.exports返回,所以会导致报错,说s不是一个function。

所以:

请牢记:require方法返回的是module.exports

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js实现跨域的多种方法
Dec 25 Javascript
谈一谈javascript中继承的多种方式
Feb 19 Javascript
js仿支付宝多方框输入支付密码效果
Sep 27 Javascript
微信小程序 定位到当前城市实现实例代码
Feb 23 Javascript
如何抽象一个Vue公共组件
Oct 17 Javascript
详解vue-cli之webpack3构建全面提速优化
Dec 25 Javascript
layui结合form,table的全选、反选v1.0示例讲解
Aug 15 Javascript
小程序兼容安卓和IOS数据处理问题及坑
Sep 18 Javascript
简单说说如何使用vue-router插件的方法
Apr 08 Javascript
微信小程序canvas开发水果老虎机的思路详解
Feb 07 Javascript
Vue实现简单计算器
Jan 20 Vue.js
JS前端使用canvas实现扩展物体类和事件派发
Aug 05 Javascript
jQuery ajax请求struts action实现异步刷新
Apr 19 #jQuery
JS正则验证多个邮箱完整实例【邮箱用分号隔开】
Apr 19 #Javascript
微信小程序 登录的简单实现
Apr 19 #Javascript
微信小程序开发入门基础教程
Apr 19 #Javascript
微信小程序教程系列之视图层的条件渲染(10)
Apr 19 #Javascript
JS实现AES加密并与PHP互通的方法分析
Apr 19 #Javascript
vue2.0父子组件间通信的实现方法
Apr 19 #Javascript
You might like
php使用date和strtotime函数输出指定日期的方法
2014/11/14 PHP
通过php修改xml文档内容的方法
2015/01/23 PHP
PHP执行系统命令函数实例讲解
2021/03/03 PHP
IE中radio 或checkbox的checked属性初始状态下不能选中显示问题
2009/07/25 Javascript
使用Firebug对js进行断点调试的图文方法
2011/04/02 Javascript
基于jquery实现的文字淡入淡出效果
2013/11/14 Javascript
Iframe实现跨浏览器自适应高度解决方法
2014/09/02 Javascript
node.js中格式化数字增加千位符的几种方法
2015/07/03 Javascript
jQuery zclip插件实现跨浏览器复制功能
2015/11/02 Javascript
每天一篇javascript学习小结(Boolean对象)
2015/11/12 Javascript
jQuery过滤选择器用法示例
2016/09/12 Javascript
微信小程序 video组件详解
2016/10/25 Javascript
vue element-ui 绑定@keyup事件无效的解决方法
2018/03/09 Javascript
使用Vue-cli 3.0搭建Vue项目的方法
2018/06/07 Javascript
前端axios下载excel文件(二进制)的处理方法
2018/07/31 Javascript
vue-router 实现导航守卫(路由卫士)的实例代码
2018/09/02 Javascript
深入了解响应式React Native Echarts组件
2019/05/29 Javascript
解决vue.js提交数组时出现数组下标的问题
2019/11/05 Javascript
Vue中Table组件行内右键菜单实现方法(基于 vue + AntDesign)
2019/11/21 Javascript
Python挑选文件夹里宽大于300图片的方法
2015/03/05 Python
Python六大开源框架对比
2015/10/19 Python
Python 由字符串函数名得到对应的函数(实例讲解)
2017/08/10 Python
python merge、concat合并数据集的实例讲解
2018/04/12 Python
Python Selenium 之关闭窗口close与quit的方法
2019/02/13 Python
Pandas0.25来了千万别错过这10大好用的新功能
2019/08/07 Python
树莓派4B+opencv4+python 打开摄像头的实现方法
2019/10/18 Python
numpy矩阵数值太多不能全部显示的解决
2020/05/14 Python
解决html5中的video标签ios系统中无法播放使用的问题
2020/08/10 HTML / CSS
科室工作个人总结的自我评价
2013/10/29 职场文书
毕业生简历自我评价范文
2014/04/09 职场文书
教师民族团结演讲稿
2014/08/27 职场文书
遗嘱继承权公证书
2015/01/26 职场文书
校园文化艺术节开幕词
2016/03/04 职场文书
Ajax实现异步加载数据
2021/11/17 Javascript
Python+OpenCV实现图片中的圆形检测
2022/04/07 Python
Windows Server 2019 配置远程控制以及管理方法
2022/04/28 Servers