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

module.exports和exports用于node模块块开发,属于 CommonJS 模块规范;export和export default用于ES6中模块块开发,是属于ES6语法。

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

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

1.针对CommonJs:

module.exports和exports导出模块,用require引入模块,对应导入require(‘xxx模块’)。

module.exports用法

通过module.exports 输出变量x

var x=5;
module.exports.x=x;

require 方法用于加载模块

var x =require('./x.js');
console.log(x);

exports 与 module.exports

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

var exports = module.exports

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

总结:module.exports = {},可以导出变量、常量、方法、对象、导入的时候不能按需导入,只能一次性导入所有内容,类似于export default{}

2.ES6语法

export和export default导出模块,import导入模块,对应导入import XXX from 'xxx模块’。

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

(1)export导出:

//demo.js
export const str = '12312'; // 变量
export function func(a){ //函数
    return a+1;
}

对应的导入方式:

import {str,func } from 'demo';  // 也可以分开两次写,导入时要带{}

console.log(str);  // 12312
console.log(func(2));  //3

总结:export{}可以导出变量、常量、方法、对象、但是在导入的时候需要用{}分别引入导出的名称,{}里面的名称需要和到处时的名称一致,顺序可以不一致,优点是可以按需导入,提高性能。

(2)export default导出

//demo1.js
export default {
    name:'123123'
}

import方法用于加载模块

import demo1 from 'demo1'; //导入时没有{}

console.log(demo1.name);  // 12312

总结:export default{}可以导出变量、常量、方法、对象、无需使用{},但是弊端是全部导入,不能按需导入。

总结一些用法上的区别:

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

module.exports = ...
exports = ...

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

export default ...
export ...

 

posted @ 2022-09-06 18:15  时光独醒  阅读(166)  评论(0编辑  收藏  举报