module

export命令

常用的三種方式
第一種方式,可以直接導(dǎo)出變量,函數(shù),class

//a.js
export let name="張三豐";
export let age=123;
export function getName(){
  return name;
}
export class Person{}

第二種方式,直接用大括號(hào)包起來倒出去

let name="張三豐";
let age=123;
function getName(){
  return name;
}
export {name,age,getName};

第三種方式 ,讓輸出的變量重命名

let name="張三豐";
let age=123;
function getName(){
  return name;
}
setTimeout(()=>{
  age=18;
});
export {name as xingming,age as nianling,getName as getXingmign};

export語句輸出的接口,與其對(duì)應(yīng)的值是動(dòng)態(tài)綁定關(guān)系,即通過該接口,可以取到模塊內(nèi)部實(shí)時(shí)的值。setTimeout可以證明這個(gè)

export對(duì)頂?shù)氖菍?duì)外的接口,必須與模塊內(nèi)部的變量建立一一對(duì)應(yīng)的關(guān)系,下面這幾種都是錯(cuò)誤的

export 1;
// 報(bào)錯(cuò)

var m = 1;
export m;
// 報(bào)錯(cuò)

上面兩種寫法都會(huì)報(bào)錯(cuò),因?yàn)闆]有提供對(duì)外的接口。第一種寫法直接輸出 1,第二種寫法通過變量m,還是直接輸出 1。1只是一個(gè)值,不是接口。

export default命令

export default 在一個(gè)模塊內(nèi)只允許出現(xiàn)一次
export可以直接導(dǎo)出匿名函數(shù)或者聲明函數(shù)

export default function (){
  console.log("匿名函數(shù)");
};
export default function funName(){
  console.log("有名字的函數(shù)");
}

因?yàn)閑xport default命令其實(shí)是輸出一個(gè)叫做default的變量,所以后面不能跟聲明變量語句

//錯(cuò)誤的
export default var a=0;
//正確的
var a=0;
export default a;

export default 輸出類

export default class{

}

import from命令

  1. import會(huì)提升到整個(gè)模塊的頭部,首先執(zhí)行,所以放到那里都行,最好放到代碼的頭部,增加易讀性
  2. 因?yàn)閕mport是靜態(tài)執(zhí)行,所以不能是用表達(dá)式和變量,比如變量,表達(dá)式,if結(jié)構(gòu)等,在靜態(tài)分析階段,這些語法是沒有是沒法得到值的,否則會(huì)報(bào)錯(cuò)

import的三種常用表達(dá)形式
第一種方式對(duì)應(yīng)export的第一種方式或者第二種方式

import {name,age,getName} from './a.js';

第二種方式,讓輸出的變量重命名

import {xingming as name,nianling as age,getXingmign as getName} from "./a.js";

第三種方式是星號(hào)*代替大括號(hào)

import * as person from "./a.js";

對(duì)應(yīng)的export default命令,變量不用加大括號(hào)

import unknown from "./a.js"http://unknown 這個(gè)是一個(gè)變量名字,可以隨便取一個(gè)

一條import語句同時(shí)輸入默認(rèn)方法和其它接口,可以寫成下面這樣,其實(shí)就是前面是指默認(rèn)的方法,后面跟著個(gè)逗號(hào),后面就是三種常用的表達(dá)方式

import num,* as person from "./a.js";//num這個(gè)是一個(gè)變量名字,可以隨便取一個(gè)

export和import的復(fù)合寫法

export {name,age} from "./a,js";

上面的代碼其實(shí)就是下面這兩條語句的復(fù)合寫法

import {name,age} from "./a.js";
export {name,age};

接口改為默認(rèn)接口寫法

export {job as default} from "./a.js";

默認(rèn)接口改為接口的方法

export {default as job} from "./a.js";
帶有*號(hào)的現(xiàn)在沒有對(duì)應(yīng)的復(fù)合寫法

module的加載方式

加上defer或者async腳本都是異步執(zhí)行,但是不同的是defer是“渲染完再執(zhí)行”,async是“下載完就執(zhí)行”。

<script src="./a.js" defer></script>
<script src="./a.js" async></script>

加載規(guī)則
瀏覽器加載 ES6 模塊,也使用<script>標(biāo)簽,但是要加入type="module"屬性。

<script type="module" src="./a.js"></script>

瀏覽器對(duì)于帶有type="module"的<script>,都是異步加載,不會(huì)造成堵塞瀏覽器,即等到整個(gè)頁面渲染完,再執(zhí)行模塊腳本,等同于打開了<script>標(biāo)簽的defer屬性。

關(guān)于class就介紹這么多,希望對(duì)你有所幫助,如果想看更詳細(xì)的資料,請(qǐng)狠狠的點(diǎn)擊我

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,702評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,143評(píng)論 3 415
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,553評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,620評(píng)論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,416評(píng)論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,940評(píng)論 1 321
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,024評(píng)論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,170評(píng)論 0 287
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,709評(píng)論 1 333
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,597評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,784評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,291評(píng)論 5 357
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,029評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,407評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,663評(píng)論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,403評(píng)論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,746評(píng)論 2 370

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

  • 認(rèn)識(shí)模塊 JS 作為一名編程語言,一直以來沒有模塊的概念。嚴(yán)重導(dǎo)致大型項(xiàng)目開發(fā)受阻,js 文件越寫越大,不方便維護(hù)...
    faremax閱讀 644評(píng)論 0 0
  • Module 語法 ES6 模塊不是對(duì)象,而是通過 export 命令顯示指定輸出的代碼,再通過 import 命...
    Mjericho閱讀 619評(píng)論 0 0
  • Module 1.ES6在語言標(biāo)準(zhǔn)的層面上,實(shí)現(xiàn)了模塊功能,成為瀏覽器和服務(wù)器通用的模塊解決方案,完全可以取代 C...
    Cryptic閱讀 7,191評(píng)論 0 11
  • 這種加載稱為“運(yùn)行時(shí)加載”,因?yàn)橹挥羞\(yùn)行時(shí)才能得到這個(gè)對(duì)象,導(dǎo)致完全沒辦法在編譯時(shí)做“靜態(tài)優(yōu)化”。 ES6 模塊不...
    codeSirCao閱讀 515評(píng)論 0 0
  • 歷史上,JavaScript 一直沒有模塊(module)體系,無法將一個(gè)大程序拆分成互相依賴的小文件,再用簡(jiǎn)單的...
    木中木閱讀 857評(píng)論 0 0