Vue3之动态组件和异步组件
创始人
2025-05-29 04:33:30

何为动态组件

动态组件是根据数据的变化,可以随时切换不同的组件,比如咱们现在要展示一个文本框和输入框,我们想要根据我们data中定义的值去决定是显示文本框还是输入框,如果用以前学的知识去做的话就是使用v-show的方式去做,虽然也能实现,但是比较复杂,代码也多了很多,这时候用动态组件能很好的解决这个问题

何为异步组件

异步组件可以以异步的方式加载组件,实际项目中我们可以把大型的项目拆分成许多小js文件,等使用时再组合,而且可以实现懒加载,有些组件暂时不需要展示给用户的我们可以等用户看到时再加载进来。

示例解析

动态组件

展示一个输入框或者文本,通过一个按钮,点击后可以切换展示,比如当前展示文本,点击按钮就会变为展示输入框,代码如下:

首先我们先定义两个组件,一个展示输入框,一个展示文本

  app.component('input-item',{template:``});app.component('common-item',{template:`
hello world
`});

定义一个currentItem变量用于控制组件的展示

data() {return {currentItem: 'input-item'}},

使用组件时使用component关键字 ,然后使用:is = "显示具体组件的依赖数据(本例子中时currentItem)"的方式动态加载组件

  template: ``

keep-alive:组件切换时在组件中的值会被清掉,比如输入框中的值,所以需要使用keep-alive来防止值被清理

定义点击按钮后执行的方法,这个方法就是改变current Item的值,让其显示不同的组件

 methods: {handleClick(){if(this.currentItem === 'input-item'){this.currentItem = 'common-item';}else{this.currentItem = 'input-item';}}}

所有代码:



动态组件

异步组件

假如我们要展示一个文本,这个文本不会马上展示,而是4秒后再展示

首先定义两个组件,一个同步组件,一个异步组件
定义同步组件

 app.component('common-item',{template:`
hello world
`})

定义异步组件,使用Vue.defineAsyncComponent定义异步组件

 app.component('async-common-item',Vue.defineAsyncComponent(()=>{return new Promise((resolve,reject)=>{setTimeout(()=>{resolve({template:`
this is an async component
`})},4000) })}));

使用组件

 const app = Vue.createApp({template: `
`});

全部代码:



异步组件

总结

本文主要是简单介绍了动态组件和异步组件的定义及使用的方法,动态组件是可以让我们使用者通过一定的条件决定展示哪个组件,而异步组件可以让我们实现组件懒加载的功能,使大型项目可以拆成许多小js文件,使用时再组合,非常方便

相关内容

热门资讯

世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...