前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >module.exports 、exports、export、export default的区别

module.exports 、exports、export、export default的区别

作者头像
wfaceboss
发布2019-04-08 10:32:50
9K0
发布2019-04-08 10:32:50
举报
文章被收录于专栏:wfacebosswfaceboss

module.exports和exports是属于 CommonJS 模块规范,export和export default是属于ES6语法。

module.exportsexports导出模块,用require引入模块。

exportexport default导出模块,import导入模块。

Node应用由模块组成,采用CommonJS模块规范。根据这个规范,每个文件就是一个模块,有自己的作用域。在一个文件里面定义的变量、函数、类,都是私有的,对其他文件不可见。

CommonJS规范规定,每个模块内部,module变量代表当前模块。这个变量是一个对象,它的exports属性(即module.exports)是对外的接口。加载某个模块,其实是加载该模块的module.exports属性。

1.针对CommonJs:

使用步骤:

(1)使用module.exports导出模块:

新建一个文件demo.js,通过module.exports输出变量x和函数add。

代码语言:javascript
复制
var x = 1;
var add = function (val) {
  return val + x;
};
module.exports.x = x;
module.exports.add = add;

(2)使用require引入模块

require方法用于加载模块。

代码语言:javascript
复制
var demo = require('./demo.js');

console.log(demo.x); // 1
console.log(demo.add(1)); // 6

exports 与 module.exports

为了方便,Node为每个模块提供一个exports变量,指向module.exports。这等同在每个模块头部,有一行这样的命令。

代码语言:javascript
复制
var exports = module.exports;

exports其实是module.exports的引用 ,可以直接在exports对象上添加相关的方法。

2.ES6

通过export方式导出,在导入时要加{ },export default则不需要,使用export default命令,为模块指定默认输出,这样就不需要知道所要加载模块的变量名。

具体使用: 

  (1)export导出:

代码语言:javascript
复制
//demo1.js
export const str = 'hello world'  //变量

export function fuunc(a){ //函数
    return a+1
}
代码语言:javascript
复制
对应的导入方式:
代码语言:javascript
复制
//demo2.js
import { str, func } from 'demo' //也可以分开写两次,导入的时候带花括号

(2)export default

代码语言:javascript
复制
//demo1.js
export default const str = 'hello world'

对应的导入方式:

代码语言:javascript
复制
//demo2.js
import str from 'demo1' //导入的时候没有花括号

总结一些用法上的区别:

(1)module.exports和exports的用法是后面加一个等号,再接具体的导出

代码语言:javascript
复制
module.exports=...
exports=...

(2)export和export default的用法是后面直接接具体的导出,没有等号.

代码语言:javascript
复制
export ...
export default ...
代码语言:javascript
复制
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-12-10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档