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

网站备案要求网络架构拓扑

网站备案要求,网络架构拓扑,四川省工程建设管理协会网站,广西网站建设产品介绍组件懒加载 前言 组件懒加载最常用于异步加载大型/复杂组件或在需要时才进行加载 Vue 2和Vue 3均支持组件懒加载,本文将介绍如何在Vue 2和Vue 3中实现组件懒加载,和一些使用场景 1️⃣方法一:使用Webpack的代码分割能力 Vue 2和Vue 3都可以…

组件懒加载

前言

组件懒加载最常用于异步加载大型/复杂组件或在需要时才进行加载
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.yayakq.cn/news/203708/

相关文章:

  • 网站降权怎么办建设银行网站怎样查询贷款信息查询
  • 网站建设公司海报酒店推广平台有哪些
  • 南充北京网站建设承德网站建设电话
  • 手机端网站ui做多少像素个人空间网站建设报告
  • 旅游网站制作代码深圳市房屋管理局官方网站
  • 学做美食视频网站有哪些通过百度指数不能判断出
  • 百度seo优化及推广seo搜索引擎优化主要做什么
  • 做班级相册网站的目的意义酒店的网站建设方案
  • vs 2008 建立网站淮南官网
  • 如何自己做优惠券网站中国企业网中国商报
  • 济南网站维护公司网站怎么做房源
  • 中山大兴网站建设长春seo公司
  • 湟源县网站建设怀化市住房与城乡建设厅网站
  • 营销型定制网站芜湖先锋网站两学一做
  • 如何 做镜像网站php网站开发教程培训
  • 汽车用品东莞网站建设珠海网站建设q.479185700強
  • 建设网站的公司排名百度快速收录seo工具软件
  • 网站界面是什么做的wordpress remove_query_arg
  • 回收网站怎么做详情页模板 套用
  • 昆明手机网站开发企业管理培训课程班
  • 企业建设H5响应式网站的5大好处中国新闻社官方网站
  • 弹簧东莞网站建设如何设置网站根目录
  • 厦门旅游网站建设商务网站建设流程
  • 资兴市网站建设哪个好青海企业网站建设公司
  • 成都装饰网站建设广州哪里能看海
  • 六安网站制作公司价格成都品牌网站建设
  • 浙江人工智能建站系统软件怎么做繁体字网站
  • 湖南好搜网站建设公众号怎么引流推广
  • 如何提高一个网站安卓手机本地视频播放器
  • 子页网站设计怎么做弹幕视频网站