异步组件核心知识点

文章目录

一、核心概念区分

  1. 普通组件:注册时直接传入组件对象,项目启动一次性加载所有代码,全局/局部注册后直接渲染,无延迟。
  2. 异步组件:注册时传入异步回调函数,项目启动仅注册组件名,首次用到时才触发回调加载组件代码,实现按需加载,减少首屏体积。

二、2种组件的注册&使用对比

javascript 复制代码
js
  
// 普通组件:直接引入+注册(一次性加载)
import MyNormal from './MyNormal.vue'
// 全局注册普通组件
Vue.component('MyNormal', MyNormal)
// 局部注册普通组件
export default { components: { MyNormal } }
 
 
js
  
// 异步组件:定义回调+注册(按需加载)
const MyAsync = () => import('./MyAsync.vue')
// 全局注册异步组件
Vue.component('MyAsync', MyAsync)
// 局部注册异步组件
export default { components: { MyAsync } }
 
 
模板使用:二者完全一致, <MyNormal/>   <MyAsync/> 

三、异步组件2种核心回调(基础/高级)

javascript 复制代码
js
  
// 基础版(项目最常用)
const AsyncBasic = () => import('./MyComponent.vue')
// 高级版(带加载/错误兜底)
const AsyncAdvance = () => ({
  component: import('./MyComponent.vue'),
  loading: () => import('./Loading.vue'),
  error: () => import('./Error.vue'),
  delay: 200, timeout: 3000
})
 

四、路由懒加载(异步组件的路由专属用法)

javascript 复制代码
js
  
const router = new VueRouter({
  routes: [
    // 普通路由(一次性加载)
    { path: '/normal', component: import('./MyNormal.vue') },
    // 路由懒加载(异步组件,按需加载)
    { path: '/async', component: () => import('./MyAsync.vue') }
  ]
})

五、异步组件的缓存规则

  1. 代码缓存:异步组件代码仅加载一次,首次触发回调后永久缓存,再次使用无需重新加载;
  2. 实例缓存:组件实例默认切走销毁,需用 包裹实现实例缓存(普通/异步组件均适用)。
javascript 复制代码
vue
  
<!-- 缓存组件实例(普通/异步都能用) -->
<keep-alive>
  <MyAsync v-if="show"/>
  <router-view/> <!-- 路由组件缓存 -->
</keep-alive>

六、异步组件底层核心(理解用,项目不用)

javascript 复制代码
js
  
// resolve由Vue自动传入,加载完成后传递组件配置给Vue
const AsyncLow = (resolve) => {
  require(['./MyComponent.vue'], resolve)
}
Vue.component('AsyncLow', AsyncLow)

核心总结

  1. 普通组件一次性加载,异步组件按需加载,核心区别在代码加载时机;
  2. 异步组件全局/局部注册均传异步回调,仅可用范围不同,触发/缓存逻辑一致;
  3. 路由懒加载=异步组件的路由版,底层逻辑完全相同,省略显式组件名注册;
  4. 异步组件默认缓存代码, 缓存实例,二者可配合使用。
相关推荐
恋猫de小郭6 小时前
AGENTS.md 真的对 AI Coding 有用吗?或许在此之前你没用对?
前端·人工智能·ai编程
sunny_7 小时前
构建工具的第三次革命:从 Rollup 到 Rust Bundler,我是如何设计 robuild 的
前端·rust·前端工程化
rfidunion8 小时前
springboot+VUE+部署(12。Nginx和前端配置遇到的问题)
前端·vue.js·spring boot
vx-Biye_Design8 小时前
servlet家政公司管理系统-计算机毕业设计源码01438
java·vue.js·spring·servlet·tomcat·maven·mybatis
珹洺8 小时前
Java-servlet(五)手把手教你利用Servlet配置HTML请求与相应
java·运维·服务器·前端·servlet·html·maven
Open Source Thoughts8 小时前
OpenClaw.ai:Agentic AI 时代的“SpringFramework”时刻
java·人工智能·spring·prompt·开源软件·agi·ai-native
forestsea8 小时前
优雅终结启动顺序噩梦:ObjectProvider —— Spring 4.3 开始引入
java·后端·spring
QQ24391978 小时前
语言在线考试与学习交流网页平台信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·spring boot·sql·学习·java-ee
想不明白的过度思考者9 小时前
JavaEE进阶 ——【SpringBoot 快速上手】从环境搭建到HelloWorld实战
java·spring boot·spring·java-ee
那我掉的头发算什么9 小时前
【SpringBoot】一篇文章讲清楚拦截器所有知识
java·spring boot·后端·spring