从品牌网站建设到网络营销策划,从策略到执行的一站式服务
这篇文章给大家介绍Node.js中exports与module.exports有什么不同,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
成都创新互联从2013年开始,先为单县等服务建站,单县等地企业,进行企业商务咨询服务。为单县企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
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("哈哈哈哈");
exports
和module.exports
的初始值指向的是空对象,即{}
。从源码可以看到,其实模块的require
方法实质上是调用了_load
方法,而_load
方法,最终返回的是module.exports
来分析一下出错的原因。
由于最开始的时候,exports
和module.exports
都指向同一个对象。
第一种方式,是在给这个空对象{}
添加属性,又因为module.exports
也是指向这个对象的,所以最终require
方法返回的module.exports
是指向了这个具有log
方法的对象的,可以引用到模块。
第二种方式是让module.exports
指向一片新的内存空间,exports
指向的仍然是{}
,但是由于require
方法返回的是module.exports
,所以最终也能引入模块。
但是最后那种写法是让exports
指向一片新的内存空间,module.exports
指向的仍然还是{}
,那么最终require
方法是将module.exports
返回,所以会导致报错,说s不是一个function。
所以:
请牢记:require
方法返回的是module.exports
!
关于Node.js中exports与module.exports有什么不同就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图