当前位置: 首页 > news >正文

Vue组件懒加载

组件懒加载

前言

组件懒加载最常用于异步加载大型/复杂组件或在需要时才进行加载
Vue 2Vue 3均支持组件懒加载,本文将介绍如何在Vue 2Vue 3中实现组件懒加载,和一些使用场景

1️⃣方法一:使用Webpack的代码分割能力

Vue 2Vue 3都可以使用,但构建打包后才能生效

const dialogInfo = () => import(/* webpackChunkName: "dialogInfo" */ '@/components/dialogInfo');

然后,就可以在需要使用该组件的地方,像使用普通组件一样引入即可:

<template><div><h1>按需加载示例</h1><dialogInfo /></div>
</template>

2️⃣方法二:使用Vue异步组件

Vue2使用

Vue 2 中,可以使用 Vue.component() 方法来注册异步组件,其中异步组件选项是一个返回包含组件信息的对象的函数。具体使用方式如下:

//基本用法:
Vue.component('async-component', () => import('./MyComponent.vue'))
//高阶用法:
const AsyncComponent = () => ({// 异步方法返回要加载的组件component: import('./MyComponent.vue'),// 组件加载期间显示的组件loading: LoadingComponent,// 加载出错时显示的组件error: ErrorComponent,// 延迟显示加载状态(以毫秒为单位)。默认值:`200`。delay: 200,// 等待时间长度等于或超过 `delay`,loadingComponent 将被渲染。如果设置为 0,则始终呈现loadingComponent。timeout: 3000
});
Vue.component('async-component', AsyncComponent);

在上述示例中,我们使用 Vue.component() 方法将名为 async-component 的异步组件注册到全局组件库中。对于高阶用法,我们定义了一个包装器函数 AsyncComponent(),它返回一个包含组件相关信息的对象。

Vue3使用

Vue 3 中,推荐使用 defineAsyncComponent() 函数来定义异步组件。该函数接受一个参数,即异步组件选项或动态导入方法,并返回一个组件实例。具体使用方式如下:

import { defineAsyncComponent } from 'vue';
//基本用法
const AsyncComponent = defineAsyncComponent(() => import('./MyComponent.vue'))
//高阶用法
const AsyncComponent = defineAsyncComponent({// 异步方法返回要加载的组件loader: () => import('./MyComponent.vue'),// 组件加载期间显示的组件loadingComponent: LoadingComponent,// 加载出错时显示的组件errorComponent: ErrorComponent,// 如果设置为 `true`,将使用Suspense包装该组件。默认值:`false`。suspense: false,// 延迟显示加载状态(以毫秒为单位)。默认值:`200`。delay: 200,// 等待时间长度等于或超过 `delay`,loadingComponent 将被渲染。如果设置为 0,则始终呈现loadingComponent。timeout: 3000,
})

在上述示例中,我们使用 defineAsyncComponent() 函数将名为 AsyncComponent 的异步组件定义为一个返回加载组件的函数。与 Vue 2 不同的是,在 Vue 3 中异步组件选项可以是一个对象,而不仅仅是一个返回对象的函数。

Vue 3 中使用 defineAsyncComponent() 定义包装了 Suspense 的异步组件的示例代码:

import { defineAsyncComponent } from 'vue';const AsyncComponent = defineAsyncComponent({loader: () => import('./MyComponent.vue'),suspense: true,delay: 200
});// 在模板中使用异步组件
<template><Suspense><template #default><AsyncComponent /></template><template #fallback><!-- 加载中的提示 --></template></Suspense>
</template>

无论是 Vue 2还是 Vue 3,一旦异步组件注册成功,就可以像普通组件一样进行使用

3️⃣组件懒加载的使用场景

有时资源拆分的过细也不好,可能会造成浏览器http请求的增多

总结出三种适合组件懒加载的场景:

  • JS 文件体积大的页面:在加载复杂的页面时,将某些组件定义为异步可以显著提高页面的加载速度
  • 按需触发的组件:只有在该组件真正需要使用时才去加载相应的资源,从而避免不必要及浪费的加载
  • 多页面复用的组件:对于包含大量数据的长列表,您可能希望只在需要滚动到屏幕上的部分时才加载列表

结语

感谢读者阅读并关注博客文章,并对文章中提到的观点、建议或批评表示感谢

http://www.lryc.cn/news/62906.html

相关文章:

  • Qt音视频开发42-网络推流(视频推流/本地摄像头推流/桌面推流/网络摄像头转发推流等)
  • 更简单的存取Bean方式-@Bean方法注解
  • 边缘计算与AI布署应用电力物联网解决方案-RK3588开发平台
  • centos部署unity accelerator
  • HANA开发指南
  • 请问你见过吐代码的泡泡吗(冒泡排序)
  • 【VM服务管家】VM4.0平台SDK_2.1环境配置类
  • 最新研究:可审计的具有拜占庭鲁棒的联邦学习方案
  • JDK1.8下载、安装和环境配置教程
  • 天津超算,青索帮助文档
  • SpringMVC的拦截器和异常处理器
  • 查看库文件是32位还是64位|查看lib是静态库还是导入库|判断是debug模式还是release模式
  • Python小姿势 - Python爬取数据的库——Scrapy
  • [C++初阶]栈和队列_优先级队列的模拟实现 deque类 的理解
  • Spring是什么?关于Spring家族
  • 自然语言处理数据集集锦(持续更新ing...)
  • 93、Dehazing-NeRF: Neural Radiance Fields from Hazy Images
  • JAVA子类与继承
  • 62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库
  • 【分布式搜索引擎ES01】
  • 1.3 鞅、停时和域流-鞅(布朗运动与随机计算【习题解答】)
  • 十、ElasticSearch 实战 - 源码运行
  • GPT-3 论文阅读笔记
  • 方案解析丨数字人主播如何成为电商直播新标配
  • Python最全迭代器有哪些?
  • ESP32 网络计时器,包含自动保存
  • 【ChatGPT】阿里版 ChatGPT 突然官宣意味着什么?
  • IPEmotion控制模块-PID循环应用
  • 【元分析研究方法】学习笔记2.检索文献(含100种学术文献搜索清单链接)
  • 题目:16版.自由落体