vue2的异步组件
在vue2中我常用的导入异步组件的方式
new Vue({// ...components: {'my-component': () => import('./my-async-component')}})
vue3的异步组件
在大型应用中,我们可能需要将应用分割成小一些的代码块,并且只在需要的时候才从服务器加载一个模块。为了简化,Vue 有一个 defineAsyncComponent 方法:
defineAsyncComponent
参数
对于基本用法,defineAsyncComponent 可以接受一个返回 Promise 的工厂函数。Promise 的 resolve 回调应该在服务端返回组件定义后被调用。你也可以调用 reject(reason) 来表示加载失败。
import { defineAsyncComponent } from 'vue'const AsyncComp = defineAsyncComponent(() =>import('./components/AsyncComponent.vue'))app.component('async-component', AsyncComp)
当使用局部注册时,你也可以直接提供一个返回 Promise 的函数:
import { createApp, defineAsyncComponent } from 'vue'createApp({// ...components: {AsyncComponent: defineAsyncComponent(() =>import('./components/AsyncComponent.vue'))}})
对于高阶用法,defineAsyncComponent 可以接受一个对象:defineAsyncComponent 方法还可以返回以下格式的对象:
import { defineAsyncComponent } from 'vue'const AsyncComp = defineAsyncComponent({// 工厂函数loader: () => import('./Foo.vue')// 加载异步组件时要使用的组件loadingComponent: LoadingComponent,// 加载失败时要使用的组件errorComponent: ErrorComponent,// 在显示 loadingComponent 之前的延迟 | 默认值:200(单位 ms)delay: 200,// 如果提供了 timeout ,并且加载组件的时间超过了设定值,将显示错误组件// 默认值:Infinity(即永不超时,单位 ms)timeout: 3000,// 定义组件是否可挂起 | 默认值:truesuspensible: false,/**** @param {*} error 错误信息对象* @param {*} retry 一个函数,用于指示当 promise 加载器 reject 时,加载器是否应该重试* @param {*} fail 一个函数,指示加载程序结束退出* @param {*} attempts 允许的最大重试次数*/onError(error, retry, fail, attempts) {if (error.message.match(/fetch/) && attempts <= 3) {// 请求发生错误时重试,最多可尝试 3 次retry()} else {// 注意,retry/fail 就像 promise 的 resolve/reject 一样:// 必须调用其中一个才能继续错误处理。fail()}}})
