最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

exports和module.exports

来源:动视网 责编:小采 时间:2020-11-27 20:31:32
文档

exports和module.exports

exports和module.exports:虽然暂时工作上没有用到commonJS的模块化写法,但是还是经常看到这种写法的源码或者文章,有时候看到exports和module.exports就有点儿傻傻分不清楚了。我想初学者可能会和我一样的疑问吧,结果一查还真是一大把。看了几篇文章,其中stackover
推荐度:
导读exports和module.exports:虽然暂时工作上没有用到commonJS的模块化写法,但是还是经常看到这种写法的源码或者文章,有时候看到exports和module.exports就有点儿傻傻分不清楚了。我想初学者可能会和我一样的疑问吧,结果一查还真是一大把。看了几篇文章,其中stackover


虽然暂时工作上没有用到commonJS的模块化写法,但是还是经常看到这种写法的源码或者文章,有时候看到exports和module.exports就有点儿傻傻分不清楚了。。我想初学者可能会和我一样的疑问吧,结果一查还真是一大把。看了几篇文章,其中stackoverflow上有个哥们写的很好,故记录在此。

  其实记住和理解这张图就很容易区分了:


  这个图展示了两者的关系,为了方便理解,我觉得可以这么来解释,当一个js文件需要模块化的时候,node环境中会给文件注入exports和module.exports这两个变量,并且刚开始的时候这两个变量是指向同一个空对象的,随后你拿着这两个变量做了一系列操作后,注意这是关键: 只有module.exports会被返回 以便后续其他模块require引用使用。

  所以到这里只是解释了运行的关系,那为啥弄两个呢?对啊为啥啊?只要module.exports不就行了,你赋值给它返回也是它多好多正常,非要弄个exports干啥幺蛾子。。哈哈,我理解的是,没错,你总是用module.exports是可以的而且不会出错,但是每次都这么写:

module.exports.a = 1; 
module.exports.b = function() {}; 
module.exports.c = 'ccc';

觉得累么??那这样写好了:

exports.a = 1; 
exports.b = function() {}; 
exports.c = 'ccc';

矣是不是清爽一些?矣?难道就是我了少写才弄出来exports的么。。我觉得好像是的哈哈哈,程序员都是极懒主义者嘛。 那么问题来了,那都用exports好了,不用module.exports呗,那可要小心了,弄不好会出错,比如:

exports = function A() {}


  你想导出一个类,写成这个样子,想想上面那张图上的话,返回的可是module.exports,这里的赋值把exports和module.exports的关系打断了,所以你引用的时候会得到什么呢?没错,空的对象。。

  所以结论呢?

当你想导出的东东可以在空对象上直接扩展就可以的时候,用exports当然省时省力

当你想导出的东东要完全覆盖掉空对象的时候,只能用module.exports了

当你傻傻分不清楚的时候请用module.exports。。


  其实不用这么麻烦,每次写的时候想想那张图和那句话,一切都顺其自然了不是,哎~为了少写点儿代码可是要好好学习啊!!

文档

exports和module.exports

exports和module.exports:虽然暂时工作上没有用到commonJS的模块化写法,但是还是经常看到这种写法的源码或者文章,有时候看到exports和module.exports就有点儿傻傻分不清楚了。我想初学者可能会和我一样的疑问吧,结果一查还真是一大把。看了几篇文章,其中stackover
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top