<返回

vue3 vite异步组件及路由懒加载怎么应用

时间:2023-05-19

一、前言

1-1.三点变化:

  • 异步组件声明方法的改变:Vue 3.x 新增一个辅助函数defineAsyncComponent,用来显示声明异步组件

  • 异步组件高级声明方法中的 component 选项更名为loader

  • loader绑定的组件加载函数不再接收resolve和reject参数,而且必须返回一个Promise

1-2.引入辅助函数defineAsyncComponent的原因:

现在,在 Vue 3 中,由于函数组件被定义为纯函数,异步组件定义需要通过将其包装在一个新的 defineAsyncComponent helper 中来显式定义。

二、Vue 2.x与Vue 3.x定义比较

2-1.异步组件/路由定义比较

  • 2-1-1.在 Vue 2.x 中,声明一个异步组件只需这样:

const asyncPage = () => import('./views/home.vue')
  • 2-1-2.在 Vue 3.x 中,异步组件的导入需要使用辅助函数defineAsyncComponent来进行显式声明。如下:

<template>  <div>    <h2>Async Components</h2>    <p>异步组件测试</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中异步组件的声明有更高级的声明方式。如下:

const asyncPageWithOptions  = {  component: () => import('./views/home.vue'),  delay: 200,  timeout: 3000,  error: ErrorComponent,  loading: LoadingComponent}

所以,下面的异步组件声明:

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

等价于:

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.异步组件加载函数返回比较

  • 2-3-1.在Vue 2.x中接收resolve和reject:

// 2.x versionconst oldAsyncComponent = (resolve, reject) => {  /* ... */}
  • 2-3-2.在Vue 3.x中始终返回Promise:

// 3.x versionconst asyncComponent = defineAsyncComponent(  () => new Promise((resolve, reject) => {      /* ... */  }))

Vue 3.x的异步组件加载函数将不再接收resolve和reject,而且必须始终返回Promise。换句话说,在Vue 3.x中,不再支持通过工厂函数接收resolve回调来定义异步组件。

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

三、Vue3实践

提示: 如果是用vite工具来构建项目,在本地开发使用import做路由懒加载,可以正常加载,但是会报警告;打包到生产环境会报错,页面不会正常展示,可以使用以下两种方法来实现。

3-1.路由懒加载实现

  • 3-1-1.defineAsyncComponent方法

// router/index.jsimport { 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.上面的方法相当于一次性加载了 views 目录下的所有.vue文件,返回一个对象const modules = import.meta.glob('../views/*/*.vue');const modules ={    "../views/about/index.vue": () => import("./src/views/about/index.vue")}// 2.动态导入的时候直接,引用const router = createRouter({  history: createWebHistory(),  routes: [    // ...    {      path: 'xxxx',      name: 'xxxxx',      // 原来的方式,这个在开发中可行,但是生产中不行      // component: () => import(`../views${menu.file}`),      // 改成下面这样      component: modules[`../views${filename}`]    }    // ...            ],})

3-2.异步组件实现

<template>  <div>    <h2>Async Components</h2>    <p>异步组件测试</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>

以上就是vue3 vite异步组件及路由懒加载怎么应用的详细内容,更多请关注Gxl网其它相关文章!

相关文章
最新文章
热门推荐
网友评论