vue3 + vite實(shí)現(xiàn)異步組件和路由懶加載

Vue2 中来庭,異步組件和路由懶加載處理使用 import 就可以很輕松實(shí)現(xiàn)。但是在Vue 3.x 中異步組件的使用與 Vue 2.x 完全不同了驮吱。本文就詳細(xì)講講vue3異步組件路由懶加載的實(shí)現(xiàn)。

Vue3 異步組件/路由

一、前言

1-1.三點(diǎn)變化:

  1. 異步組件聲明方法的改變:Vue 3.x 新增一個(gè)輔助函數(shù)defineAsyncComponent腐巢,用來(lái)顯示聲明異步組件
  2. 異步組件高級(jí)聲明方法中的 component 選項(xiàng)更名為loader
  3. loader綁定的組件加載函數(shù)不再接收resolvereject參數(shù),而且必須返回一個(gè)Promise

1-2.引入輔助函數(shù)defineAsyncComponent的原因:

現(xiàn)在玄括,在 Vue 3 中冯丙,由于函數(shù)組件被定義為純函數(shù),異步組件定義需要通過(guò)將其包裝在一個(gè)新的 defineAsyncComponent helper 中來(lái)顯式定義遭京。

二胃惜、Vue 2.x與Vue 3.x定義比較

2-1.異步組件/路由定義比較

  • 2-1-1.在 Vue 2.x 中,聲明一個(gè)異步組件只需這樣:
const asyncPage = () => import('./views/home.vue')
  • 2-1-2.在 Vue 3.x 中哪雕,異步組件的導(dǎo)入需要使用輔助函數(shù)defineAsyncComponent來(lái)進(jìn)行顯式聲明船殉。如下:
<template>
  <div>
    <h1>Async Components</h1>
    <p>異步組件測(cè)試</p>
    <child />
  </div>
</template>

<script>
import { defineAsyncComponent } from 'vue'
const child = defineAsyncComponent(() => import('@/components/async-component-child.vue'))

export default {
  name: 'async-components',
  components:{
    'child': child
  }
};
</script>

2-2.聲明方式比較

  • 2-2-1.Vue 2.x中異步組件的聲明有更高級(jí)的聲明方式。如下:
const asyncPageWithOptions  = {
  component: () => import('./views/home.vue'),
  delay: 200,
  timeout: 3000,
  error: ErrorComponent,
  loading: LoadingComponent
}

所以斯嚎,下面的異步組件聲明:

const asyncPage = () => import('./views/home.vue')

等價(jià)于:

const asyncPageWithOptions  = {
  component: () => import('./views/home.vue')
}
  • 2-2-2.Vue 3.x中也可以這樣聲明異步組件利虫。只是其中的component需要改為loader挨厚。如下:
const asyncPageWithOptions  = defineAsyncComponent({
  loader: () => import('./views/home.vue'),
  delay: 200,
  timeout: 3000,
  error: ErrorComponent,
  loading: LoadingComponent
})

2-3.異步組件加載函數(shù)返回比較

  • 2-3-1.在Vue 2.x中接收resolvereject
// 2.x version
const oldAsyncComponent = (resolve, reject) => {
  /* ... */
}
  • 2-3-2.在Vue 3.x中始終返回Promise
// 3.x version
const asyncComponent = defineAsyncComponent(
  () => new Promise((resolve, reject) => {
      /* ... */
  })
)

Vue 3.x的異步組件加載函數(shù)將不再接收resolvereject,而且必須始終返回Promise糠惫。也就是說(shuō)幽崩,工廠函數(shù)接收 resolve 回調(diào)的方式定義異步組件在 Vue 3.x 不能使用了。

// 在 Vue 3.x 中不適用
export default {
  components: {
    asyncPage: resolve => require(['@/components/list.vue'], resolve)
  },
}

三寞钥、Vue3實(shí)踐

提示: 如果是用vite工具來(lái)構(gòu)建項(xiàng)目慌申,在本地開(kāi)發(fā)使用import路由懶加載,可以正常加載理郑,但是會(huì)報(bào)警告蹄溉;打包到生產(chǎn)環(huán)境會(huì)報(bào)錯(cuò),頁(yè)面不會(huì)正常展示您炉,可以使用以下兩種方法來(lái)實(shí)現(xiàn)柒爵。

3-1.路由懶加載實(shí)現(xiàn)

  • 3-1-1.defineAsyncComponent方法
// router/index.js
import { defineAsyncComponent } from 'vue'
const _import = (path) => defineAsyncComponent(() => import(`../views/${path}.vue`));

const routes = [
  {
    path: '/async-component',
    name: 'asyncComponent',
    component: _import('home'),
  }
];
  • 3-1-2.import.meta.glob方法
// 1.上面的方法相當(dāng)于一次性加載了 views 目錄下的所有.vue文件,返回一個(gè)對(duì)象
const modules = import.meta.glob('../views/*/*.vue');
const modules ={
    "../views/about/index.vue": () => import("./src/views/about/index.vue")
}

// 2.動(dòng)態(tài)導(dǎo)入的時(shí)候直接赚爵,引用
const router = createRouter({
  history: createWebHistory(),
  routes: [
    // ...
    {
      path: 'xxxx',
      name: 'xxxxx',
      // 原來(lái)的方式棉胀,這個(gè)在開(kāi)發(fā)中可行,但是生產(chǎn)中不行
      // component: () => import(`../views${menu.file}`),
      // 改成下面這樣
      component: modules[`../views${filename}`]
    }
    // ...          
  ],
})

3-2.異步組件實(shí)現(xiàn)

<template>
  <div>
    <h1>Async Components</h1>
    <p>異步組件測(cè)試</p>
    <child></child>
  </div>
</template>

<script>
import { defineAsyncComponent } from 'vue'
const child = defineAsyncComponent(() => import('@/components/async-component-child.vue'))

export default {
  name: 'async-components',
  components:{
    'child': child
  }
};
</script>

四冀膝、總結(jié)

簡(jiǎn)單來(lái)說(shuō)唁奢,寫在路由配置文件中的異步加載就是路由懶加載的用法,而寫在組件內(nèi)部的異步加載就是異步組件用法窝剖。


《Vue3學(xué)習(xí)與實(shí)戰(zhàn)》系列


歡迎訪問(wèn):個(gè)人博客地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末麻掸,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子赐纱,更是在濱河造成了極大的恐慌脊奋,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,590評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件疙描,死亡現(xiàn)場(chǎng)離奇詭異诚隙,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)起胰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門久又,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人待错,你說(shuō)我怎么就攤上這事籽孙。” “怎么了火俄?”我有些...
    開(kāi)封第一講書人閱讀 169,301評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵犯建,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我瓜客,道長(zhǎng)适瓦,這世上最難降的妖魔是什么竿开? 我笑而不...
    開(kāi)封第一講書人閱讀 60,078評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮玻熙,結(jié)果婚禮上否彩,老公的妹妹穿的比我還像新娘。我一直安慰自己嗦随,他們只是感情好列荔,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,082評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著枚尼,像睡著了一般贴浙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上署恍,一...
    開(kāi)封第一講書人閱讀 52,682評(píng)論 1 312
  • 那天崎溃,我揣著相機(jī)與錄音,去河邊找鬼盯质。 笑死袁串,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的呼巷。 我是一名探鬼主播囱修,決...
    沈念sama閱讀 41,155評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼朵逝!你這毒婦竟也來(lái)了蔚袍?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 40,098評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤配名,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后晋辆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體渠脉,經(jīng)...
    沈念sama閱讀 46,638評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,701評(píng)論 3 342
  • 正文 我和宋清朗相戀三年瓶佳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了芋膘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,852評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡霸饲,死狀恐怖为朋,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情厚脉,我是刑警寧澤习寸,帶...
    沈念sama閱讀 36,520評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站傻工,受9級(jí)特大地震影響孵滞,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鸯匹,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,181評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望殴蓬。 院中可真熱鬧,春花似錦染厅、人聲如沸根蟹。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,674評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)简逮。三九已至,卻和暖如春尿赚,著一層夾襖步出監(jiān)牢的瞬間散庶,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,788評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工凌净, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留悲龟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,279評(píng)論 3 379
  • 正文 我出身青樓冰寻,卻偏偏與公主長(zhǎng)得像须教,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子斩芭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,851評(píng)論 2 361

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