Node 浅谈module.exports与exports的区别

在这里插入图片描述

一、前提操作

首先我们新建两个页面,demo.js 和 module.js,我们需要把 demo.js 引入 module.js 页面,并在 node 的环境下运行。那我们该怎么导出呢?

有两种方式,即 module.exports 与 exports,那这两种方式,又有什么区别呢?接下来,我们一起了解一下。

首先你要知道:module 代表的是当前模块的本身,exports 就是 module 的属性,其实说穿了,exports 就是 module 的引用。我们在导出其他页面时,既可以使用 exports 导出,也可以使用 module.exports 导出。

那么是不是,我们在导出时,就可以随意使用了?其实不然,这两者还是有区别的,下来我们通过具体案例,进行学习。

二、初识区别

如果一条数据或多条数据,我们一条一条数据进行导出,那么我们使用 module.exports 和 exports 导出效果都是一样的。
在这里插入图片描述

三、问题发现

我们主要看一下,用对象的形式一次性导出多条数据,如下所示:

1、我们首先使用 module.exports 的方式,进行导出,在我们的 demo.js,书写如下代码:

module.exports = {
	name : '孙悟空',
	age : 20,
	run : function(){
		console.log('十万八千里');
	}
}

2、在我们的 module.js,书写如下代码:

var md = require('./demo.js');   //.js后缀名可不写
console.log(md.name);
console.log(md.age);
md.run();

3、在我们 node 环境下,运行,效果如下:

孙悟空
20
十万八千里

我们可以很清楚的看到,此页面我们已导出成功。

那么接下来,我们用 exports,试一试:

1、在我们的 demo.js,我们书写如下代码:

exports = {
	name : '孙悟空',
	age : 20,
	run : function(){
		console.log('十万八千里');
	}
}

2、module.js 页面与上面一样,代码不变。
3、下来我们在 node 环境下,运行,效果如下:
在这里插入图片描述
⚠ 我们可以很清楚的看见,报错了!

那是为什么呢?请查看,下篇博客:Node 深究module.exports与exports的区别,我们详细进行讲解,感谢您的阅读与支持!

发布了161 篇原创文章 · 获赞 71 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/qq_44034384/article/details/99542263
今日推荐