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文件,使用时再组合,非常方便

相关内容

热门资讯

cad打印线条粗细设置 cad... 004-线型(下)打印样式设置和线型文件使用一、线宽设置方法制图规范里边的线宽要求,我们已经定义好,...
荼蘼什么意思 岁月缱绻葳蕤生香... 感谢作者【辰夕】的原创独家授权分享编辑整理:【多肉植物百科】百科君坐标:云南 曲靖春而至,季节流转,...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...