首先主要体现在他们的用法上,
require是CommonJS的语法,它的模块是对象,导入时实际倒入一个对象,然后再根据对象去查找对应的属性。所以会可能加载一些模块内不被用到的方法或其他
let { stat, exists, readFile } = require('fs');
// 等同于
let _fs = require('fs');
let stat = _fs.stat;
这里涉及到一个概念,叫‘运行时加载‘,就是说,只有在代码真正运行的时候才会去加载对应需要的东西,所以不能做到编译时就把想加载的模块加载进来,即不能做到编译时静态化。
而import是属于ES6内的,es6默认使用严格模式,模块内的变量在外部是无法使用的,必须通过exports导出。.ES6 模块的设计思想,是尽量的静态化,使得编译时就能确定模块的依赖关系,以及输入和输出的变量。
export var firstName = 'Michael';
export {firstName, lastName, year};
export function multiply(x, y) {
return x * y;
}; //导出函数或者类
export {
v1 as streamV1,
v2 as streamV2,
v2 as streamLatestVersion
}; //用as重命名
与之对应的是需要import引入
import {firstName, lastName, year} from './profile';
import { lastName as surname } from './profile'; //重命名
import * as circle from './circle'; //用星号代表所有
import命令接受一对大括号,里面指定要从其他模块导入的变量名,必须与被导入模块(profile.js)对外接口的名称相同。
适用场景就是按需加载和条件加载