require()
require([module],callback)
define()
export() import()
ES6 模块的设计思想是尽量的静态化,使得编译时就能确定模块的依赖关系,以及输入和输出的变量。CommonJS 和 AMD 模块,都只能在运行时确定这些东西。比如,CommonJS 模块就是对象,输入时必须查找对象属性
import { stat, exists, readFile } from ‘fs‘;
上面代码的实质是从fs
模块加载 3 个方法,其他方法不加载。这种加载称为“编译时加载”或者静态加载,即 ES6 可以在编译时就完成模块加载,效率要比 CommonJS 模块的加载方式高。当然,这也导致了没法引用 ES6 模块本身,因为它不是对象
// profile.js
export var firstName = ‘Michael‘;
export var lastName = ‘Jackson‘;
export var year = 1958;
OR
// profile.js
var firstName = ‘Michael‘;
var lastName = ‘Jackson‘;
var year = 1958;
export { firstName, lastName, year };
// main.js
import { firstName, lastName, year } from ‘./profile.js‘;
function setName(element) {
element.textContent = firstName + ‘ ‘ + lastName;
}
import { lastName as surname } from ‘./profile.js‘;
原文:https://www.cnblogs.com/yeni/p/12711819.html