ES6 模块
模块化的大同世界
从 ECMAScript2015/ECMAScript6
开始,JavaScript
原生引入了模块概念,而且现在主流浏览器也都有了很好的支持,同时在 Node.js
也有了支持,所以未来基于 JavaScript
的程序无论是在前端浏览器还是在后端 Node.js
中,都会逐渐的被统一
1 独立模块作用域
一个文件就是模块,拥有独立的作用域,且导出的模块都自动处于 严格模式
下,即:'use strict'
script
标签需要声明 type="module"
2 导出模块内部数据
使用 export
语句导出模块内部数据
javascript
// 导出单个特性
export let name1, name2, …, nameN;
export let name1 = …, name2 = …, …, nameN;
export function FunctionName(){...}
export class ClassName {...}
// 导出列表
export { name1, name2, …, nameN };
// 重命名导出
export { variable1 as name1, variable2 as name2, …, nameN };
// 默认导出
export default expression;
export default function (…) { … }
export default function name1(…) { … }
export { name1 as default, … };
// 模块重定向导出
export * from …;
export { name1, name2, …, nameN } from …;
export { import1 as name1, import2 as name2, …, nameN } from …;
export { default } from …;
注意,export
命令规定的是对外的接口,必须与模块内部的变量建立一一对应关系:
报错:
js
// 写法一
export 1;
// 写法二
var m = 1;
export m;
正常:
js
// 写法一
export var m = 1;
// 写法二
var m = 1;
export {m};
// 写法三
var n = 1;
export {n as m};
3 导入外部模块数据
导入分为两种模式
- 静态导入
- 动态导入
静态导入
使用 import
语句导入模块,这种方式称为:静态导入
静态导入方式不支持延迟加载。注意,import
命令具有提升效果,会提升到整个模块的头部,首先执行。
javascript
import defaultExport from "module-name"; // 加载默认输出
import * as name from "module-name"; // 模块的整体加载
import { export } from "module-name";
import { export as alias } from "module-name";
import { export1 , export2 } from "module-name";
import { foo , bar } from "module-name/path/to/specific/un-exported/file";
import { export1 , export2 as alias2 , [...] } from "module-name";
import defaultExport, { export [ , [...] ] } from "module-name";
import defaultExport, * as name from "module-name";
import "module-name";
javascript
document.onclick = function () {
// import 必须放置在当前模块最开始加载
// import m from './m.js'
// console.log(m);
}
动态导入
此外,还有一个类似函数的动态 import()
,它不需要依赖 type="module"
的 script 标签。
关键字 import
可以像调用函数一样来动态的导入模块。以这种方式调用,将返回一个 promise
javascript
import('./m.js')
.then(m => {
//...
});
// 也支持 await
let m = await import('./m.js');
通过
import()
方法导入返回的数据会被包装在一个对象中,即使是default
也是如此