export用于对外输出本模块(一个文件可以理解为一个模块)变量的接口
import用于在一个模块中加载另一个含有export接口的模块
export default 和 export 的区别
-
export与export default均可用于导出常量、函数、文件、模块等
-
可以在其它文件或模块中通过import+(常量 | 函数 | 文件 | 模块)名的方式,将其导入,以便能够对其进行使用
-
在一个文件或模块中,export、import可以有多个,export default仅有一个
-
通过export方式导出,在导入时要加{ },export default则不需要
-
其实很多时候export与export default可以实现同样的目的,只是用法有些区别。注意第四条,通过export方式导出,在导入时要加{ },export default则不需要。使用export default命令,为模块指定默认输出,这样就不需要知道所要加载模块的变量名
切记,注意以下代码的区别
export default const a =1 // 错误
const a =1
export default a // 正确
export const a =1 // 正确
const/let是ES6关键字,如果default后跟const之类的关键字是不符合的,
ES6规范中标记出了default后面能带的参数
究其本质,export default 命令其实,是将该命令后面的值赋给default变量以后再默认,只是输出了一个叫做 default 的变量,所以export default的后面不能跟变量声明语句
export default a 的含义是将变量a的值赋给变量default