由一個bug引出的對ES6模塊的總結(jié)和思考

其實(shí)是很明顯的一個bug周偎。

項(xiàng)目中有一個入口React組件Root來做一些初始化的工作抹剩,其中包含初始化全局變量,偽代碼如下:

import './Page.js';

class Root extends React.Component {
  componentDidMount() {
    initGlobal();
  }

  initGlobal() {
    global.isIOS = true;
    // ...
  }
}

獲取設(shè)備信息deviceInfo.js(在下面的Page.js用到了):

export function getStatusBarHeight() {
  if (global.isIOS) {
    return 20;
  } else {
    return 44; 
  }
}

還有一個頁面組件Page.js(會被加載到):

import { getStatusBarHeight } from './deviceInfo.js';

const statusBarHeight = getStatusBarHeight();

class Page extends React.Component {
  render() {
    <div style={{paddingTop: statusBarHeight}}></div>
  }
}

然后大家應(yīng)該猜到了在Page.js中執(zhí)行getStatusBarHeight()的時候每次都是44蓉坎,因?yàn)閳?zhí)行的時候global.isIOS是undefined澳眷。原因是執(zhí)行const statusBarHeight = getStatusBarHeight();的時候global.isIOS還沒初始化。

我在寫deviceInfo.js的時候心里默認(rèn)global已經(jīng)加載OK了才導(dǎo)致了這個問題蛉艾,這讓我思考后面應(yīng)該如何來避免這個問題:

不要使用全局變量钳踊!全局的變量都放到模塊中衷敌,使用的時候從模塊中加載就不會出現(xiàn)這個問題了。(不用全局變量這個道理大家都知道拓瞪,卻不是每個人都可以做到)


正好趁這個機(jī)會又復(fù)習(xí)了下ES6的模塊的東西缴罗,筆記如下:

ES6的模塊是在編譯的時候就可以確認(rèn)模塊的依賴關(guān)系,AMD只有運(yùn)行的時候才可以確認(rèn)祭埂,所以相比AMD的模塊系統(tǒng)面氓,ES6的模塊系統(tǒng)會有幾個好處(相比AMD之類來說):

  • 可以只加載用到的東西,比如import { every } from 'lodash'蛆橡,這樣只會把lodash的every方法加載進(jìn)來舌界,而不是加載整個lodash對象。
  • 編譯的時候就完成模塊加載泰演,所以執(zhí)行效率更高呻拌。

不能把import用到表達(dá)式,變量和if語句之類的睦焕,因?yàn)檫@些無法通過靜態(tài)檢查藐握,只有運(yùn)行的時候才會得到結(jié)果。但是這樣就限制了動態(tài)加載了垃喊,實(shí)際上現(xiàn)在ES6已經(jīng)有了草案來支持動態(tài)加載了猾普,目前通過babel也可以實(shí)現(xiàn)。

模塊加載順序沒有統(tǒng)一規(guī)范本谜。

參考:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末抬闷,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子耕突,更是在濱河造成了極大的恐慌,老刑警劉巖评架,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件眷茁,死亡現(xiàn)場離奇詭異,居然都是意外死亡纵诞,警方通過查閱死者的電腦和手機(jī)上祈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來浙芙,“玉大人登刺,你說我怎么就攤上這事∥撕簦” “怎么了纸俭?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長南窗。 經(jīng)常有香客問我揍很,道長郎楼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任窒悔,我火速辦了婚禮呜袁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘简珠。我一直安慰自己阶界,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布聋庵。 她就那樣靜靜地躺著膘融,像睡著了一般。 火紅的嫁衣襯著肌膚如雪珍策。 梳的紋絲不亂的頭發(fā)上托启,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天,我揣著相機(jī)與錄音攘宙,去河邊找鬼屯耸。 笑死,一個胖子當(dāng)著我的面吹牛蹭劈,可吹牛的內(nèi)容都是我干的疗绣。 我是一名探鬼主播,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼铺韧,長吁一口氣:“原來是場噩夢啊……” “哼多矮!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起哈打,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤塔逃,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后料仗,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體湾盗,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年立轧,在試婚紗的時候發(fā)現(xiàn)自己被綠了格粪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡氛改,死狀恐怖帐萎,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情胜卤,我是刑警寧澤疆导,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站葛躏,受9級特大地震影響是鬼,放射性物質(zhì)發(fā)生泄漏肤舞。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一均蜜、第九天 我趴在偏房一處隱蔽的房頂上張望李剖。 院中可真熱鬧,春花似錦囤耳、人聲如沸篙顺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽德玫。三九已至,卻和暖如春椎麦,著一層夾襖步出監(jiān)牢的瞬間宰僧,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工观挎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留琴儿,地道東北人。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓嘁捷,卻偏偏與公主長得像造成,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子雄嚣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評論 2 354

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