fangchaolong
文章57
标签24
分类10
export、export default、module.export区别

export、export default、module.export区别

首先要知道export,import ,export default是什么

ES6模块主要有两个功能:export和import
export用于对外输出本模块(一个文件可以理解为一个模块)变量的接口
import用于在一个模块中加载另一个含有export接口的模块。
也就是说使用export命令定义了模块的对外接口以后,其他JS文件就可以通过import命令加载这个模块(文件)。这几个都是ES6的语法。

export和import(一个导出一个导入)##

一个a.js文件有如下代码:
export var name=”李四”;
在其它文件里引用如下:

active

上面的例子是导出单个变量的写法,如果是导出多个变量就应该按照下边的方法,用大括号包裹着需要导出的变量:

var name1=”李四”;
var name2=”张三”;
export { name1 ,name2 }

在其他文件里引用如下:

active2

如果导出的是个函数呢,那应该怎么用呢,其实一样,如下
active3

在其他文件里引用如下:
active4

export与export default##

这2者区别:在同一个文件里面可以有多个export, 一个文件里面只能有1个export default
看完上面这几个例子,想必你一定了解了如何使用export,import,如果还是不懂可以自己动手试一试。上面讲的是export和import,但是export跟export default 有什么区别呢?如下:

  1. export与export default均可用于导出常量、函数、文件、模块等
  2. 你可以在其它文件或模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使用
  3. 在一个文件或模块中,export、import可以有多个,export default仅有一个
  4. 通过export方式导出,在导入时要加{ },export default则不需要

这样来说其实很多时候export与export default可以实现同样的目的,只是用法有些区别。注意第四条,通过export方式导出,在导入时要加{ },export default则不需要。使用export default命令,为模块指定默认输出,这样就不需要知道所要加载模块的变量名。

在es5中,用module.exportsexports导出模块,用require引入模块。
es6新增exportexport default导出模块,import导入模块。

无以生计,卖文苟延

微信
支付宝