require 和 import 的区别

首先主要体现在他们的用法上,

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)对外接口的名称相同。

适用场景就是按需加载和条件加载

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容