解密vue异步组件

1、异步组件用法

js 复制代码
Vue.component(  
    'async-webpack-example',   
    () => import('./my-async-component')  
)

2、使用场景

如果我们需要展示某个产品的信息,产品关联的tab页面有20个,使用异步组件就使得代码很简单,减少了组件的注册

js 复制代码
<template> 
   <el-tabs v-model="activeName" @tab-click="handleClick"> 
       <el-tab-pane label="基本信息" name="first"></el-tab-pane> 
       <el-tab-pane label="配置信息" name="second"></el-tab-pane> 
       <el-tab-pane label="角色信息" name="third"></el-tab-pane> 
       <el-tab-pane label="部门信息" name="fourth"></el-tab-pane> 
       ...
       <el-tab-pane label="其他信息" name="twenty"></el-tab-pane>
    </el-tabs> 
    
    <async-webpack-example />
</template> 
<script> 
  export default { 
      data() { return { activeName: 'second' }; }, 
      methods: { 
        handleClick(path) { 
           Vue.component(  
                'async-webpack-example',   
                () => import('./my-async-component/'+ path)  
            )
        } 
      } 
   }; 
 </script>

3、源码

  1. 使用defineAsyncComponent定义异步组件,它返回一个包装了异步加载逻辑的组件选项对象。

  2. 创建一个占位符组件,在异步组件加载完成前用于渲染。

  3. 在占位符组件的渲染函数中处理异步加载逻辑,返回一个Suspense组件用于展示加载状态。

  4. 使用import()动态导入组件模块,返回一个 Promise 对象。

  5. 创建异步组件的渲染函数,根据组件的选项对象创建。

  6. 替换占位符组件,将异步组件渲染到占位符组件的位置。

4、编译原理

疑问:webpack编译是按需加载,也就是我们用到了哪些代码,才会进行编译打包。当我们使用异步组件的时候,path是一个变量,如何做到把这些路径的文件提前编译呢?

带着这样的疑问我们来看看 Vue.component 的编译代码吧

欢迎关注我的前端自检清单,我和你一起成长

相关推荐
一 乐5 小时前
智慧养老|基于springboot+小程序社区养老保障系统设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端·小程序
老华带你飞6 小时前
旅游|基于Java旅游信息推荐系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·旅游
老华带你飞6 小时前
医院挂号|基于Java医院挂号管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
yzx9910137 小时前
基于Flask+Vue.js的智能社区垃圾分类管理系统 - 三创赛参赛项目全栈开发指南
vue.js·分类·flask
+VX:Fegn08957 小时前
人力资源管理|基于springboot + vue人力资源管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
一 乐7 小时前
海鲜商城购物|基于SprinBoot+vue的海鲜商城系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot
Nan_Shu_6148 小时前
熟悉RuoYi-Vue-Plus-前端 (2)
前端·javascript·vue.js
用户841794814568 小时前
vxe-gantt vue table 甘特图子任务多层级自定义模板用法
vue.js
还算善良_8 小时前
【Vue】vue3实现文件预览组件(预览服务使用kkfileview)
javascript·vue.js·ecmascript
北辰alk8 小时前
从零构建Vue项目的完全指南:手把手打造现代化前端工程
vue.js