ES6:模塊(Module)

基本用法

命名導(dǎo)出(named exports)

可以直接在任何變量或者函數(shù)前面加上一個(gè) export 關(guān)鍵字病苗,就可以將它導(dǎo)出葵姥。
這種寫法非常簡(jiǎn)潔紊浩,和平時(shí)幾乎沒有區(qū)別,唯一的區(qū)別就是在需要導(dǎo)出的地方加上一個(gè) export 關(guān)鍵字酌呆。
比如:

export const sqrt = Math.sqrt;
export function square(x) {
    return x * x;
}
export function diag(x, y) {
    return sqrt(square(x) + square(y));
}

然后在另一個(gè)文件中這樣引用:

import { square, diag } from 'lib';
console.log(square(11)); // 121
console.log(diag(4, 3));

你可能會(huì)注意到這個(gè)奇怪的語法 { square, diag } 不就是前面講過的 destructing嗎衡载。所以你會(huì)以為還可以這樣寫:

 import lib from 'lib';
 square = lib.square;

但是其實(shí)這樣是錯(cuò)的,因?yàn)?import { square, diag } from 'lib’; 是import的特有語法隙袁,并不是 destructing 語法痰娱,所以其實(shí)import的時(shí)候并不是直接把整個(gè)模塊以對(duì)象的形式引入的。

如果你希望能通過 lib.square 的形式來寫菩收,你應(yīng)該這樣導(dǎo)入:

 import * as lib from 'lib';
 square = lib.square;

不過值得注意的一點(diǎn)是梨睁,如果你直接用babel編譯,執(zhí)行是會(huì)報(bào)錯(cuò)的娜饵。因?yàn)?babel 并不會(huì)完全編譯 modules坡贺,他只是把 ES6 的modules語法編譯成了 CMD 的語法,所以還需要用 browserify 之類的工具再次編譯一遍箱舞。
如果你發(fā)現(xiàn) browserify 找不到 lib遍坟,可以改成 from ‘./lib’ 試試。

默認(rèn)導(dǎo)出

大家會(huì)發(fā)現(xiàn)上面的寫法比較麻煩晴股,因?yàn)楸仨氁付ㄒ粋€(gè)名字愿伴。其實(shí)很多時(shí)候一個(gè)模塊只導(dǎo)出了一個(gè)變量,根本沒必要指定一個(gè)名字电湘。
還有一種用法叫默認(rèn)導(dǎo)出隔节,就是指定一個(gè)變量作為默認(rèn)值導(dǎo)出:

 //------ myFunc.js ------
export default function () { ... };

//------ main1.js ------
import myFunc from 'myFunc';
myFunc();

默認(rèn)導(dǎo)出的時(shí)候不需要指定一個(gè)變量名,它默認(rèn)就是文件名寂呛。
這里的區(qū)別不僅僅是不用寫名字怎诫,而是 導(dǎo)出的默認(rèn)值就是模塊本身,而不是模塊下面的一個(gè)屬性贷痪,即是 import myFunc from 'myFunc’; 而不是 import {myFunc} from 'myFunc’;

命名導(dǎo)出結(jié)合默認(rèn)導(dǎo)出

默認(rèn)導(dǎo)出同樣可以結(jié)合命名導(dǎo)出來使用:

export default function (obj) {
    ...
};
export function each(obj, iterator, context) {
    ...
}
export { each as forEach };

上面的代碼導(dǎo)出了一個(gè)默認(rèn)的函數(shù)幻妓,然后由導(dǎo)出了兩個(gè)命名函數(shù),我們可以這樣導(dǎo)入:

 import _, { each } from 'underscore';

注意這個(gè)逗號(hào)語法呢诬,分割了默認(rèn)導(dǎo)出和命名導(dǎo)出

其實(shí)這個(gè)默認(rèn)導(dǎo)出只是一個(gè)特殊的名字叫 default涌哲,你也可以就直接用他的名字胖缤,把它當(dāng)做命名導(dǎo)出來用尚镰,下面兩種寫法是等價(jià)的:

import { default as foo } from 'lib';
import foo from 'lib';

同樣的,你也可以通過顯示指定 default 名字來做默認(rèn)導(dǎo)出, 下面兩種寫法是一樣的:

 //------ module1.js ------
export default 123;

//------ module2.js ------
const D = 123;
export { D as default };

僅支持靜態(tài)導(dǎo)入導(dǎo)出

ES6規(guī)范只支持靜態(tài)的導(dǎo)入和導(dǎo)出哪廓,也就是必須要在編譯時(shí)就能確定狗唉,在運(yùn)行時(shí)才能確定的是不行的,比如下面的代碼就是不對(duì)的:

//動(dòng)態(tài)導(dǎo)入
var mylib;
if (Math.random()) {
    mylib = require('foo');
} else {
    mylib = require('bar');
}
//動(dòng)態(tài)導(dǎo)出
if (Math.random()) {
    exports.baz = ...;
}

為什么要這么做涡真,主要是兩點(diǎn):

性能分俯,在編譯階段即完成所有模塊導(dǎo)入肾筐,如果在運(yùn)行時(shí)進(jìn)行會(huì)降低速度
更好的檢查錯(cuò)誤,比如對(duì)變量類型進(jìn)行檢查
各種導(dǎo)入和導(dǎo)出方式總結(jié)

總結(jié)一下缸剪,ES6提供了如下幾種導(dǎo)入方式:

// Default exports and named exports
import theDefault, { named1, named2 } from 'src/mylib';
import theDefault from 'src/mylib';
import { named1, named2 } from 'src/mylib';

// Renaming: import named1 as myNamed1
import { named1 as myNamed1, named2 } from 'src/mylib';

// Importing the module as an object
// (with one property per named export)
import * as mylib from 'src/mylib';

// Only load the module, don’t import anything
import 'src/mylib';

如下幾種導(dǎo)出方式:

 //命名導(dǎo)出
export var myVar1 = ...;
export let myVar2 = ...;
export const MY_CONST = ...;

export function myFunc() {
    ...
}
export function* myGeneratorFunc() {
    ...
}
export class MyClass {
    ...
}
// default 導(dǎo)出
export default 123;
export default function (x) {
    return x
};
export default x => x;
export default class {
    constructor(x, y) {
        this.x = x;
        this.y = y;
    }
};
//也可以自己列出所有導(dǎo)出內(nèi)容
const MY_CONST = ...;
function myFunc() {
    ...
}

export { MY_CONST, myFunc };
//或者在導(dǎo)出的時(shí)候給他們改個(gè)名字
export { MY_CONST as THE_CONST, myFunc as theFunc };

//還可以導(dǎo)出從其他地方導(dǎo)入的模塊
export * from 'src/other_module';
export { foo, bar } from 'src/other_module';
export { foo as myFoo, bar } from 'src/other_module';
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末吗铐,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子杏节,更是在濱河造成了極大的恐慌唬渗,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件奋渔,死亡現(xiàn)場(chǎng)離奇詭異镊逝,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)嫉鲸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門撑蒜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人玄渗,你說我怎么就攤上這事座菠。” “怎么了藤树?”我有些...
    開封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵辈灼,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我也榄,道長(zhǎng)巡莹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任甜紫,我火速辦了婚禮降宅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘囚霸。我一直安慰自己腰根,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開白布拓型。 她就那樣靜靜地躺著额嘿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪劣挫。 梳的紋絲不亂的頭發(fā)上册养,一...
    開封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音压固,去河邊找鬼球拦。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的坎炼。 我是一名探鬼主播愧膀,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼谣光!你這毒婦竟也來了檩淋?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤萄金,失蹤者是張志新(化名)和其女友劉穎狼钮,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體捡絮,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡熬芜,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了福稳。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片涎拉。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖的圆,靈堂內(nèi)的尸體忽然破棺而出鼓拧,到底是詐尸還是另有隱情,我是刑警寧澤越妈,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布季俩,位于F島的核電站,受9級(jí)特大地震影響梅掠,放射性物質(zhì)發(fā)生泄漏酌住。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一阎抒、第九天 我趴在偏房一處隱蔽的房頂上張望酪我。 院中可真熱鬧,春花似錦且叁、人聲如沸都哭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽欺矫。三九已至,卻和暖如春展氓,著一層夾襖步出監(jiān)牢的瞬間穆趴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來泰國(guó)打工带饱, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留毡代,地道東北人阅羹。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓勺疼,卻偏偏與公主長(zhǎng)得像教寂,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子执庐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

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

  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持酪耕,譯者再次奉上一點(diǎn)點(diǎn)福利:阿里云產(chǎn)品券,享受所有官網(wǎng)優(yōu)惠轨淌,并抽取幸運(yùn)大...
    HetfieldJoe閱讀 3,655評(píng)論 2 27
  • 前言 承接上一篇《ES6模塊(Module)加載知識(shí)總結(jié)(一)》的兩個(gè)問題迂烁,1、 由于index.js導(dǎo)入了所有的...
    朱man閱讀 1,231評(píng)論 0 2
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理递鹉,服務(wù)發(fā)現(xiàn)盟步,斷路器,智...
    卡卡羅2017閱讀 134,638評(píng)論 18 139
  • 實(shí)踐總結(jié) 在我項(xiàng)目的目錄結(jié)構(gòu)最外層有一個(gè)components文件夾躏结,里面存放著項(xiàng)目用到的所有公共組件却盘,每個(gè)頁面用到...
    朱man閱讀 1,018評(píng)論 0 1
  • 鏡子是一個(gè)巨大的容器 盛裝著一切驕傲與丑陋
    野草小姐閱讀 176評(píng)論 0 0