vue中如何通過組件占位符動態(tài)引入組件來提高代碼效率?

<template>
  <div>
    <component :is="componentInstance" />
  </div>
</template>

<script>
export default {
  props: {
    isCompany: { type: Boolean, default: false },
  },
  computed: {
    componentInstance () {
      const name = this.isCompany ? 'CompanyInfo' : 'UserInfo'
      return () => import(`./components/${name}`)
    }
  }
}
</script>

有了上面的解決方案陶缺,import就變成了一個返回Promise的函數(shù)。如果Promise resolves(也就是說洁灵,沒有任何中斷和rejected)饱岸,它將在運行時加載所需的模塊。

那么徽千,這里發(fā)生了什么?我們仍然使用我們的新朋友<component/>苫费,提供一個完整的組件對象。
如文檔中所述双抽,:is, 和 prop可以包括以下兩種:
已注冊組件的名稱百框,或
組件的選擇對象
砰!組件的選擇對象。這正是我們需要的!
注意我們避免導入和注冊組件,因為在運行時動態(tài)導入這樣做?牍汹。
官方文檔中有更多關于Vue和動態(tài)導入的信息铐维。
一個小問題
注意我們訪問了這個道具。是動態(tài)導入語句之外的公司慎菲。
這是必須的嫁蛇,因為否則Vue無法執(zhí)行其反應魔法并在道具更改時更新計算值。試一試露该,你就會明白我的意思了睬棚。
通過訪問動態(tài)導入之外的道具(通過創(chuàng)建一個簡單的name變量),Vue知道組件實例computed屬性“依賴”于此有决。因此闸拿,當我們的道具發(fā)生變化時空盼,它將有效地引發(fā)重新評估书幕。
提醒一句(8月4日更新)
當使用動態(tài)導入時,Webpack將(在構建時)為每個匹配導入函數(shù)中的表達式的文件創(chuàng)建一個塊文件揽趾。
上面的示例有點做作台汇,但假設my /components文件夾包含800個組件。然后Webpack會創(chuàng)建800個塊篱瞎。
因為這不是我們想要的(呵呵)苟呐,所以確保您編寫更嚴格的表達式和/或遵循文件夾約定。例如俐筋,我傾向于將要分割的組件分組到一個名為/components/chunks或/components/bundle的文件夾中牵素,這樣我就知道哪些組件是Webpack分割的。
除此之外澄者,我們還得到了一個慣用的笆呆、簡潔的模式请琳。它有一個奇妙的副作用,使它真正發(fā)光:
我們的“條件”組件現(xiàn)在被分割了!
如果你像這樣運行npm構建一個組件赠幕,你會注意到Webpack會為UserInfo創(chuàng)建一個特定的bundle文件俄精。另外一個是關于companyinfo。vue的榕堰。Webpack默認情況下會這樣做竖慧。Webpack是純愛?。
這很好逆屡,因為用戶在應用程序請求這些包之前不會加載它們圾旨,從而減少了初始包大小并提高了應用程序的性能。
代碼將是涂料魏蔗。確保你熟悉它碳胳,因為如果你還沒有使用它,你可以大大提高你的應用程序沫勿。就去做吧!

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末挨约,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子产雹,更是在濱河造成了極大的恐慌诫惭,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,222評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蔓挖,死亡現(xiàn)場離奇詭異夕土,居然都是意外死亡,警方通過查閱死者的電腦和手機瘟判,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,455評論 3 385
  • 文/潘曉璐 我一進店門怨绣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人拷获,你說我怎么就攤上這事篮撑。” “怎么了匆瓜?”我有些...
    開封第一講書人閱讀 157,720評論 0 348
  • 文/不壞的土叔 我叫張陵赢笨,是天一觀的道長。 經常有香客問我驮吱,道長茧妒,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,568評論 1 284
  • 正文 為了忘掉前任左冬,我火速辦了婚禮桐筏,結果婚禮上,老公的妹妹穿的比我還像新娘拇砰。我一直安慰自己梅忌,他們只是感情好绊袋,可當我...
    茶點故事閱讀 65,696評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著铸鹰,像睡著了一般癌别。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蹋笼,一...
    開封第一講書人閱讀 49,879評論 1 290
  • 那天展姐,我揣著相機與錄音,去河邊找鬼剖毯。 笑死圾笨,一個胖子當著我的面吹牛,可吹牛的內容都是我干的逊谋。 我是一名探鬼主播擂达,決...
    沈念sama閱讀 39,028評論 3 409
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼胶滋!你這毒婦竟也來了板鬓?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,773評論 0 268
  • 序言:老撾萬榮一對情侶失蹤究恤,失蹤者是張志新(化名)和其女友劉穎俭令,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體部宿,經...
    沈念sama閱讀 44,220評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡抄腔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,550評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了理张。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赫蛇。...
    茶點故事閱讀 38,697評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖雾叭,靈堂內的尸體忽然破棺而出悟耘,到底是詐尸還是另有隱情,我是刑警寧澤拷况,帶...
    沈念sama閱讀 34,360評論 4 332
  • 正文 年R本政府宣布作煌,位于F島的核電站,受9級特大地震影響赚瘦,放射性物質發(fā)生泄漏。R本人自食惡果不足惜奏寨,卻給世界環(huán)境...
    茶點故事閱讀 40,002評論 3 315
  • 文/蒙蒙 一起意、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧病瞳,春花似錦揽咕、人聲如沸悲酷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,782評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽设易。三九已至,卻和暖如春蛹头,著一層夾襖步出監(jiān)牢的瞬間顿肺,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,010評論 1 266
  • 我被黑心中介騙來泰國打工渣蜗, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留屠尊,地道東北人。 一個月前我還...
    沈念sama閱讀 46,433評論 2 360
  • 正文 我出身青樓耕拷,卻偏偏與公主長得像讼昆,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子骚烧,可洞房花燭夜當晚...
    茶點故事閱讀 43,587評論 2 350

推薦閱讀更多精彩內容