有關(guān)es6中的import使用方法

靜態(tài)的**import** 語(yǔ)句用于導(dǎo)入由另一個(gè)模塊導(dǎo)出的綁定造挽。無(wú)論是否聲明了 strict mode 碱璃,導(dǎo)入的模塊都運(yùn)行在嚴(yán)格模式下弄痹。在瀏覽器中,import 語(yǔ)句只能在聲明了 type="module"script 的標(biāo)簽中使用嵌器。

此外界酒,還有一個(gè)類似函數(shù)的動(dòng)態(tài) import(),它不需要依賴 type="module" 的script標(biāo)簽嘴秸。

script 標(biāo)簽中使用 nomodule 屬性毁欣,可以確保向后兼容。

在您希望按照一定的條件或者按需加載模塊的時(shí)候岳掐,動(dòng)態(tài)import() 是非常有用的凭疮。而靜態(tài)型的 import 是初始化加載依賴項(xiàng)的最優(yōu)選擇,使用靜態(tài) import 更容易從代碼靜態(tài)分析工具和 tree shaking 中受益串述。

語(yǔ)法

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";
var promise = import("module-name");//這是一個(gè)處于第三階段的提案执解。

name參數(shù)是“導(dǎo)入模塊對(duì)象”的名稱,它將用一種名稱空間來(lái)引用導(dǎo)入模塊的接口纲酗。export參數(shù)指定單個(gè)的命名導(dǎo)出衰腌,而import * as name語(yǔ)法導(dǎo)入所有導(dǎo)出接口,即導(dǎo)入模塊整體觅赊。以下示例闡明該語(yǔ)法右蕊。

導(dǎo)入整個(gè)模塊的內(nèi)容

這將myModule插入當(dāng)前作用域,其中包含來(lái)自位于/modules/my-module.js文件中導(dǎo)出的所有接口吮螺。

import * as myModule from '/modules/my-module.js';

在這里饶囚,訪問(wèn)導(dǎo)出接口意味著使用模塊名稱(在本例為“myModule”)作為命名空間。例如鸠补,如果上面導(dǎo)入的模塊包含一個(gè)接口doAllTheAmazingThings()萝风,你可以這樣調(diào)用:

myModule.doAllTheAmazingThings();

導(dǎo)入單個(gè)接口

給定一個(gè)名為myExport的對(duì)象或值,它已經(jīng)從模塊my-module導(dǎo)出(因?yàn)檎麄€(gè)模塊被導(dǎo)出)或顯式地導(dǎo)出(使用export語(yǔ)句)紫岩,將myExport插入當(dāng)前作用域规惰。

import {myExport} from '/modules/my-module.js';

導(dǎo)入多個(gè)接口

這將foobar插入當(dāng)前作用域。

import {foo, bar} from '/modules/my-module.js';

導(dǎo)入帶有別名的接口

你可以在導(dǎo)入時(shí)重命名接口泉蝌。例如歇万,將shortName插入當(dāng)前作用域。

import {reallyReallyLongModuleExportName as shortName}
  from '/modules/my-module.js';

導(dǎo)入時(shí)重命名多個(gè)接口

使用別名導(dǎo)入模塊的多個(gè)接口梨与。

import {
  reallyReallyLongModuleMemberName as shortName, 
  anotherLongModuleName as short
} from '/modules/my-module.js';

僅為副作用而導(dǎo)入一個(gè)模塊

整個(gè)模塊僅為副作用(中性詞堕花,無(wú)貶義含義)而導(dǎo)入,而不導(dǎo)入模塊中的任何內(nèi)容(接口)粥鞋。 這將運(yùn)行模塊中的全局代碼, 但實(shí)際上不導(dǎo)入任何值缘挽。

import '/modules/my-module.js';

導(dǎo)入默認(rèn)值

引入模塊可能有一個(gè)defaultexport(無(wú)論它是對(duì)象,函數(shù),類等)可用壕曼。然后可以使用import語(yǔ)句來(lái)導(dǎo)入這樣的默認(rèn)接口苏研。

最簡(jiǎn)單的用法是直接導(dǎo)入默認(rèn)值:

import myDefault from '/modules/my-module.js';

也可以同時(shí)將default語(yǔ)法與上述用法(命名空間導(dǎo)入或命名導(dǎo)入)一起使用。在這種情況下腮郊,default導(dǎo)入必須首先聲明摹蘑。 例如:

import myDefault, * as myModule from '/modules/my-module.js';
// myModule used as a namespace

或者

import myDefault, {foo, bar} from '/modules/my-module.js';
// specific, named imports

動(dòng)態(tài)import

關(guān)鍵字import可以像調(diào)用函數(shù)一樣來(lái)動(dòng)態(tài)的導(dǎo)入模塊。以這種方式調(diào)用轧飞,將返回一個(gè) promise衅鹿。

import('/modules/my-module.js')
  .then((module) => {
    // Do something with the module.
  });

這種使用方式也支持 await 關(guān)鍵字。

let module = await import('/modules/my-module.js');
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末过咬,一起剝皮案震驚了整個(gè)濱河市大渤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌掸绞,老刑警劉巖泵三,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異衔掸,居然都是意外死亡烫幕,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門敞映,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)较曼,“玉大人,你說(shuō)我怎么就攤上這事驱显∈撸” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵埃疫,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我孩哑,道長(zhǎng)栓霜,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任横蜒,我火速辦了婚禮胳蛮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘丛晌。我一直安慰自己仅炊,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布澎蛛。 她就那樣靜靜地躺著抚垄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上呆馁,一...
    開(kāi)封第一講書(shū)人閱讀 51,190評(píng)論 1 299
  • 那天桐经,我揣著相機(jī)與錄音,去河邊找鬼浙滤。 笑死阴挣,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的纺腊。 我是一名探鬼主播畔咧,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼揖膜!你這毒婦竟也來(lái)了盒卸?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤次氨,失蹤者是張志新(化名)和其女友劉穎蔽介,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體煮寡,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡虹蓄,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了幸撕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片薇组。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖坐儿,靈堂內(nèi)的尸體忽然破棺而出律胀,到底是詐尸還是另有隱情,我是刑警寧澤貌矿,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布炭菌,位于F島的核電站,受9級(jí)特大地震影響逛漫,放射性物質(zhì)發(fā)生泄漏黑低。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一酌毡、第九天 我趴在偏房一處隱蔽的房頂上張望克握。 院中可真熱鬧,春花似錦枷踏、人聲如沸菩暗。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)停团。三九已至旷坦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間客蹋,已是汗流浹背塞蹭。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留讶坯,地道東北人番电。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像辆琅,于是被迫代替她去往敵國(guó)和親漱办。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容