码迷,mamicode.com
首页 > 其他好文 > 详细

exports与module.exports的区别

时间:2018-05-18 15:33:43      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:导出   err   code   内置模块   全局   cli   utils   错误   运行   

nodejs有自己的模块系统,分为文件模块和内置模块。webpack是运行在node环境中,在学习vue-cli的webpack配置的时候,

发现有的文件模块:

exports.fun1=function(param){ // } 

 exports.fun2=function(param){ // },

比如utils.js文件。。。

而有的文件模块:

module.exports = { // }

他们有什么区别呢?我只是自己的理解与资料总结,会一直更新与更改:

  • 1.每个js文件一创建,都有一个var exports = module.exports = {};,使exportsmodule.exports都指向一个空对象。
  • 2.module是全局内置对象,exports是被var创建的局部对象。
  • 3.module.exportsexports所指向的内存地址相同
  • 1.module.exports像是exports的大哥,当module.exports{}整体导出时会覆盖exports的属性和方法,
  • 2.注意,若只是将属性/方法挂载在module.exports./exports.上时,exports.id=1module.exports.id=100module.exports.id=function(){}exports.id=function(){},最后id的值取决于exports.idmodule.exports.id的顺序,谁在后,就是最后的值
  • 3.若exportsmodule.exports同时赋值时,exports所使用的属性和方法必须出现在module.exports,若属性没有在module.exports中定义的话,出现undefined,若方法没有在module.exports中定义,会抛出TypeError错误。RHS查询

总之:如果只是单一属性或方法的话,就使用exports.属性/方法。要是导出多个属性或方法或使用对象构造方法,结合prototype等,就建议使用module.exports = {}

exports与module.exports的区别

标签:导出   err   code   内置模块   全局   cli   utils   错误   运行   

原文地址:https://www.cnblogs.com/lvhuan/p/9056083.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!