defineAsyncComponent
2023年07月19日
一、认识
defineAsyncComponent
定义一个异步组件,它在运行时是懒加载的。参数可以是一个异步加载函数,或是对加载行为进行更具体定制的一个选项对象。有了 defineAsyncComponent
, 我们可以:
-
懒加载组件, 仅在页面需要它渲染时才会调用加载内部实际组件的函数。它会将接收到的
props
和插槽传给内部组件,所以你可以使用这个异步的包装组件无缝地替换原始组件,同时实现延迟加载。 -
拆分应用为更小的块,
ES
模块动态导入也会返回一个Promise
,所以多数情况下我们会将它和defineAsyncComponent
搭配使用。类似Vite
和Webpack
这样的构建工具也支持此语法 (并且会将它们作为打包时的代码分割点)
二、语法
2.1 全局
app.component('Foo',defineAsyncComponent({
loader: ()=> import("./Foo.vue"),
// 加载异步组件时使用的组件
loadingComponent: LoadingComponent,
// 展示加载组件前的延迟时间,默认为 200ms
delay: 200,
// 加载失败后展示的组件
errorComponent: ErrorComponent,
// 如果提供了一个 timeout 时间限制,并超时了
// 也会显示这里配置的报错组件,默认值是:Infinity
timeout: 3000
}));
2.2 组件
const asyncComp = defineAsyncComponent({
loader: ()=> import("./Foo.vue"),
// 加载异步组件时使用的组件
loadingComponent: LoadingComponent,
// 展示加载组件前的延迟时间,默认为 200ms
delay: 200,
// 加载失败后展示的组件
errorComponent: ErrorComponent,
// 如果提供了一个 timeout 时间限制,并超时了
// 也会显示这里配置的报错组件,默认值是:Infinity
timeout: 3000
});