簡(jiǎn)介
ES6發(fā)布之后,module成為了標(biāo)準(zhǔn),標(biāo)準(zhǔn)的文件引用是使用export指令導(dǎo)出接口,再使用import指令引入模塊。一般我們使用的是CommonJS規(guī)范,使用import導(dǎo)入模塊,使用module.exports導(dǎo)出接口。
require
require的使用非常簡(jiǎn)單,module.exports 后面是什么內(nèi)容,require獲取的就是什么內(nèi)容。
require('./a')(); // a模塊導(dǎo)出了一個(gè)函數(shù),立刻執(zhí)行這個(gè)函數(shù)
var data = require('./a').key; // a模塊導(dǎo)出了一個(gè)對(duì)象,使用key獲取value
var a = require('./a')[0]; // a模塊導(dǎo)出了一個(gè)數(shù)組
你甚至可以把 require 當(dāng)成一個(gè)node內(nèi)置的全局函數(shù),它的參數(shù)也可以是表達(dá)式:
require(process.cwd() + '/a');
但是import 不同,import是編譯的時(shí)候處理的,所以需要放在文件頭聲明。require是在執(zhí)行的時(shí)候處理的。
從理解上來(lái)說(shuō),import 是解構(gòu)過(guò)程,require是賦值過(guò)程。
More reference Link