当前位置: 首页 > news >正文

动态渲染组件

引言

在现代前端开发中,动态渲染组件是一种常见的需求,特别是在构建复杂的应用程序时。动态渲染组件允许我们在运行时根据不同的条件或数据来决定渲染哪个组件,从而提高代码的灵活性和可维护性。本文将详细介绍如何在 Vue.js 中实现动态渲染组件。

原理

Vue.js 提供了一个特殊的 <component> 元素,可以通过绑定 is 属性来动态地选择和渲染组件。<component> 元素的 is 属性可以是一个字符串,表示组件的名称,也可以是一个组件对象。

参数介绍

  • is 属性:用于指定要渲染的组件。可以是组件的名称(字符串)或组件对象。

  • v-bind:用于传递组件的属性(props)。

  • v-on:用于绑定组件的事件。

示例代码

假设我们有三个组件 A, B, 和 C,我们将通过一个按钮来切换这些组件的显示。

Acomponent.vue

<!-- Acomponent.vue -->
<template><div><h2>A组件</h2><div style="margin: auto;">接受传参: {{ text }}</div><div style="margin: auto;"><el-button type="primary" @click="handleClick">Click Me (A)</el-button></div></div>
</template><script>
export default {name: "AComponent",props: {text: {type: String,default: ""}},methods: {handleClick() {this.$emit('click', { message: 'Hello from Acomponent' });}}
}
</script><style lang="scss" scoped></style>

Bcomponent.vue

<!-- Bcomponent.vue -->
<template><div><h2>B组件</h2><div style="margin: auto;">接受传参: {{ this.text }}</div><div style="margin: auto;"><el-button type="primary" @click="handleClick">Click Me (B)</el-button></div></div>
</template><script>
export default {name: "BComponent",props: {text: {type: String,default: ""}},methods: {handleClick() {this.$emit('click', { message: 'Hello from Bcomponent' });}}
}
</script><style lang="scss" scoped></style>

CComponent.vue

<!-- CComponent.vue -->
<template><div><h2>C组件</h2><div style="margin: auto;">接受传参: {{ this.text }}</div><div style="margin: auto;"><el-button type="primary" @click="handleClick">Click Me (C)</el-button></div></div>
</template><script>
export default {name: "CComponent",props: {text: {type: String,default: ""}},methods: {handleClick() {this.$emit('click', { message: 'Hello from Ccomponent' });}}
}
</script><style lang="scss" scoped></style>

动态渲染组件
接下来,我们创建一个父组件,使用 <component> 元素来动态渲染上述组件。

<!-- index.vue -->
<template><div><el-menu :default-active="activeIndex" class="el-menu-demo tag_con" mode="horizontal" @select="handleSelect"><el-menu-item v-for="item in tagList" :key="item.type" :index="item.component">{{ item.title }}</el-menu-item></el-menu><component :is="currentComponent" v-bind="currentProps" v-on="currentEvents" /></div>
</template><script>
import Acomponent from './Acomponent.vue';
import Bcomponent from './Bcomponent.vue';
import Ccomponent from './Ccomponent.vue';export default {components: {Acomponent,Bcomponent,Ccomponent},data() {return {tagList: [{title: 'tag1',type: "1",component: "Acomponent", // 对应的组件名},{title: 'tag2',type: "2",component: "Bcomponent",},{title: 'tag3',type: "3",component: "Ccomponent",},],activeIndex: "Acomponent", // 默认激活的tag名currentComponent: 'Acomponent', // 默认渲染的的组件名currentProps: { // 传递给组件参数text: 'Component A'},};},computed: {currentEvents() {return {// 绑定事件Acomponent: { click: this.handleAEvent },Bcomponent: { click: this.handleBEvent },Ccomponent: { input: this.handleCEvent }}[this.currentComponent] || {};}},methods: {handleSelect(index) {// xuconst selectedItem = this.tagList.find(item => item.component === index);if (selectedItem) {this.currentComponent = selectedItem.component;// console.log('this.currentComponent::: ', this.currentComponent);}},handleAEvent(data) {console.log('data::: ', data);},handleBEvent(data) {console.log('data::: ', data);},handleCEvent(data) {console.log('data::: ', data);},}
};
</script>

总结

通过使用 Vue.js 的 元素和动态导入,我们可以轻松实现组件的动态渲染。这种方式不仅提高了代码的灵活性,还优化了应用的性能。希望本文能帮助你在实际项目中更好地应用动态渲染组件的技术。

相关文章:

动态渲染组件

引言 在现代前端开发中&#xff0c;动态渲染组件是一种常见的需求&#xff0c;特别是在构建复杂的应用程序时。动态渲染组件允许我们在运行时根据不同的条件或数据来决定渲染哪个组件&#xff0c;从而提高代码的灵活性和可维护性。本文将详细介绍如何在 Vue.js 中实现动态渲染…...

一个神秘的新图像生成模型red_panda出现 轻松击败Midjourney与OpenAI

一个神秘的新图像生成模型在众包人工分析基准测试中击败了 Midjourney、黑森林实验室和 OpenAI 的模型。这个名为"red_panda"的模型在人工分析的文本到图像排行榜上领先排名第二的黑森林实验室的 Flux1.1 Pro 约 40 个 Elo 分数。 Artificial Analysis 使用 Elo&…...

云计算平台上的DevOps实践

文章目录 什么是DevOps云计算平台上的DevOps优势自动化部署弹性伸缩地理分布 实施DevOps的关键组件版本控制系统持续集成/持续交付工具配置管理工具监控和日志管理 实践案例使用AWS CodePipeline进行持续集成/持续交付利用AWS Auto Scaling实现弹性使用AWS CloudFormation进行基…...

JS新功能之:全新 Set 方法

JavaScript 的内置Set类将新增一些方法&#xff0c;以便执行集合论中常见的操作&#xff0c;包括&#xff1a; Set.prototype.intersection(other)&#xff1a;返回两个集合的交集。 Set.prototype.union(other)&#xff1a;返回两个集合的并集。 Set.prototype.difference(o…...

Flume的安装配置

一、上传解压 tar -zxvf apache-flume-1.9.0-bin.tar.gz -C /usr/local/soft/#***在环境变量中增加如下命令&#xff0c;可以使用 soft 快速切换到 /usr/local/soft***alias softcd /usr/local/soft/ 二、配置环境变量 soft #重命名 mv apache-flume-1.9.0-bin/ flume-1.9.0…...

3.1.3 虚存页面的映射

3.1.3 虚存页面的映射 文章目录 3.1.3 虚存页面的映射3.1.3 虚存页面的映射MmCreateVirtualMapping&#xff08;&#xff09;MmCreateVirtualMappingUnsafe&#xff08;&#xff09;MiFlushTlb&#xff08;&#xff09;MmDeleteVirtualMapping&#xff08;&#xff09;MmPageOu…...

【SSM详细教程】-14-SpringAop超详细讲解

精品专题&#xff1a; 01.《C语言从不挂科到高绩点》课程详细笔记 https://blog.csdn.net/yueyehuguang/category_12753294.html?spm1001.2014.3001.5482 02. 《SpringBoot详细教程》课程详细笔记 https://blog.csdn.net/yueyehuguang/category_12789841.html?spm1001.20…...

虚拟机桥接模式连不上,无法进行SSH等远程操作

说明&#xff1a;以下情况在window10上遇到&#xff0c;解决后顺便做了个笔记&#xff0c;以防后续再次用到&#xff0c;也给同道中人提供一个解决方案 一、首先按照以下步骤进行检查 1、是否连接了对应的wifi 2、是否设置了桥接模式 3、上述1、2确认无误的情况下请查看右上…...

jmeter基础01-1_环境准备-windows系统安装jdk

课程大纲 一、步骤解说 step1. jdk官网下载 Java Downloads | Oracle step2. 安装/解压&#xff08;二选一&#xff09; 1. 安装包格式&#xff08;后缀.exe/.msi/.dmg&#xff09;&#xff1a;双击跟随界面向导安装&#xff0c;可以指定安装位置等。 2. 压缩包格式(后缀.z…...

第六天: C语言核心概念与实战技巧全解析

1 主函数&#xff08;main&#xff09; 大家好&#xff0c;今天我们来深入探讨一下C语言中非常特殊的一个函数——main函数。虽然大家对它并不陌生&#xff0c;但是它的重要性和特殊性值得我们再次回顾。 main函数的定义 main函数是我们整个C源程序的入口点。计算机在运行程…...

初始JavaEE篇——多线程(5):生产者-消费者模型、阻塞队列

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;JavaEE 文章目录 阻塞队列生产者—消费者模型生产者—消费者模型的优势&#xff1a;生产者—消费者模型的劣势&#xff1a; Java标准库中的阻…...

2024年下教师资格证面试报名详细流程❗

⏰ 重要时间节点&#xff1a; &#xff08;一&#xff09;下半年笔试成绩查询&#xff1a;11月8日10:00 &#xff08;二&#xff09;注册报名&#xff1a;11月8日10:00-11日18:00 &#xff08;三&#xff09;网上审核&#xff1a;11月8日10:00-11日18:00 &#xff08;四&#x…...

软考:常用协议和端口号

常用协议及其对应的端口号如下&#xff1a; TCP/IP协议&#xff1a; TCP&#xff08;传输控制协议&#xff09;&#xff1a;端口号为6UDP&#xff08;用户数据报协议&#xff09;&#xff1a;端口号为17 网络应用协议&#xff1a; HTTP&#xff08;超文本传输协议&#xff09;…...

Linux更改符号链接

目录 1. 删除旧链接 2. 创建新的符号链接 例如我的电脑上有两个版本的cuda&#xff0c;11.8和12.4 1. 删除旧链接 rm cuda 2. 创建新的符号链接 ln -s /usr/local/cuda-11.8/ /usr/local/cuda...

int main(int argc,char* argv[])详解

#include <stdio.h> //argc 是指命令行输入参数的个数; //argv[]存储了所有的命令行参数, //arg[0]通常指向程序中的可执行文件的文件名。在有些版本的编译器中还包括程序文件所在的路径。 //如:"d:\Production\Software\VC_2005_Test\Win32控制台应用程序\Vc_T…...

单片机原理及应用笔记:C51流程控制语句与项目实践

作者介绍 周瑞康&#xff0c;男&#xff0c;银川科技学院&#xff0c;计算机人工智能学院&#xff0c;2022级计算机科学与技术8班本科生&#xff0c;单片机原理及应用课程第八组。 指导老师&#xff1a;王兴泽 电子邮箱2082545622qq.com 前言&#xff1a; 本篇文章是参考《…...

大数据日志处理框架ELK方案

介绍应用场景大数据ELK日志框架安装部署 一&#xff0c;介绍 大数据日志处理框架ELK&#xff08;Elasticsearch、Logstash、Kibana&#xff09;是一套完整的日志集中处理方案&#xff0c;以下是对其的详细介绍&#xff1a; 一、Elasticsearch&#xff08;ES&#xff09; 基本…...

VQGAN(2021-06:Taming Transformers for High-Resolution Image Synthesis)

论文&#xff1a;Taming Transformers for High-Resolution Image Synthesis 1. 背景介绍 2022年中旬&#xff0c;以扩散模型为核心的图像生成模型将AI绘画带入了大众的视野。实际上&#xff0c;在更早的一年之前&#xff0c;就有了一个能根据文字生成高清图片的模型——VQGAN…...

docker中使用ros2humble的rviz2不显示问题

这里写目录标题 docker中使用ros2humble的rviz2不显示问题删除 Docker 镜像和容器删除 Docker 容器Linux服务器下查看系统CPU个数、核心数、(make编译最大的)线程数总结&#xff1a; RVIZ2 不能显示数据集 docker中使用ros2humble的rviz2不显示问题 问题描述&#xff1a; roo…...

【AIGC】2024-arXiv-Lumiere:视频生成的时空扩散模型

2024-arXiv-Lumiere: A Space-Time Diffusion Model for Video Generation Lumiere&#xff1a;视频生成的时空扩散模型摘要1. 引言2. 相关工作3. Lumiere3.1 时空 U-Net (STUnet)3.2 空间超分辨率的多重扩散 4. 应用4.1 风格化生成4.2 条件生成 5. 评估和比较5.1 定性评估5.2 …...

正则表达式:文本处理的强大工具

正则表达式是一种强大的文本处理工具&#xff0c;它允许我们通过定义一系列的规则来匹配、搜索、替换或分割文本。在编程、文本编辑、数据分析和许多其他领域中&#xff0c;正则表达式都扮演着重要的角色。本文将介绍正则表达式的基本概念、语法和一些实际应用。 正则表达式的…...

Doris单机安装

1、安装包下载 官网地址&#xff1a;https://doris.apache.org/zh-CN/docs/gettingStarted/quick-start/ 下载地址&#xff1a;https://apache-doris-releases.oss-accelerate.aliyuncs.com/apache-doris-3.0.2-bin-x64.tar.gz 2、操作系统环境准备 #环境准备 cat /proc/cp…...

ubuntu内核更新导致显卡驱动掉的解决办法

方法1&#xff0c;DKMS指定内核版本 用第一个就行 1&#xff0c;借鉴别人博客解决方法 2&#xff0c;借鉴别人博客解决方法 方法2&#xff0c;删除多于内核的方法 系统版本&#xff1a;ubuntu20.24 这个方法是下下策&#xff0c;如果重装驱动还是不行&#xff0c;就删内核在…...

【Java数据结构】树】

【Java数据结构】树 一、树型结构1.1 概念1.2 特点1.3 树的类型1.4 树的遍历方式1.5 树的表示形式1.5.1 双亲表示法1.5.2 孩子表示法1.5.3 孩子双亲表示法1.5.4 孩子兄弟表示法 二、树型概念&#xff08;重点&#xff09; 此篇博客希望对你有所帮助&#xff08;帮助你了解树&am…...

Java面试题——微服务篇

1.微服务的拆分原则/怎么样才算一个有效拆分 单一职责原则&#xff1a;每个微服务应该具有单一的责任。这意味着每个服务只关注于完成一项功能&#xff0c;并且该功能应该是独立且完整的。最小化通信&#xff1a;尽量减少服务之间的通信&#xff0c;服务间通信越少&#xff0c…...

Python 中 print 函数输出多行并且选择对齐方式

代码 # 定义各类别的标签和对应数量 categories ["class0", "class1", "class2", "class3", "class4", "class5"] counts [4953, 547, 5121, 8989, 6077, 4002]# 设置统一的列宽 column_width 10# 生成对齐后…...

书生营L0G3000 Git 基础知识

任务1: 破冰活动&#xff1a;自我介绍 用vi就行了 按照教程来就好了 git会报错密码&#xff0c;输入的时候换成token就好了 https://stackoverflow.com/questions/68775869/message-support-for-password-authentication-was-removed 提交。&#xff08;github上预览自己的…...

【C++初阶】模版入门看这一篇就够了

文章目录 1. 泛型编程2. 函数模板2. 1 函数模板概念2. 2 函数模板格式2. 3 函数模板的原理2. 4 函数模板的实例化2. 5 模板参数的匹配原则2. 6 补充&#xff1a;使用调试功能观察函数调用 3. 类模板3 .1 类模板的定义格式3. 2 类模板的实例化 1. 泛型编程 在C语言中&#xff0…...

Spring Bean创建流程

Spring Bean 创建流程图 大家总是会错误的理解Bean的“实例化”和“初始化”过程&#xff0c;总会以为初始化就是对象执行构造函数生成对象实例的过程&#xff0c;其实不然&#xff0c;在初始化阶段实际对象已经实例化出来了&#xff0c;初始化阶段进行的是依赖的注入和执行一…...

重学SpringBoot3-怎样优雅停机

更多SpringBoot3内容请关注我的专栏&#xff1a;《SpringBoot3》 期待您的点赞&#x1f44d;收藏⭐评论✍ 重学SpringBoot3-怎样优雅停机 1. 什么是优雅停机&#xff1f;2. Spring Boot 3 优雅停机的配置3. Tomcat 和 Reactor Netty 的优雅停机机制3.1 Tomcat 优雅停机3.2 Reac…...

中韩双语网站制作价格/长沙网站策划

【赛迪网讯】《varbusiness》杂志发表评论指出&#xff0c;随着开放资源软件的发展&#xff0c;Linux 大旗的挥舞者之一红帽&#xff08;Red Hat&#xff09;向外界公布了自己强劲的第二季度财政报告&#xff0c;在整个企业软件市场显现出低迷状态的趋势下&#xff0c;红帽逆潮…...

做soho建立网站/seo课程培训机构

在Vs2005中新建一个Web项目&#xff0c;添加两个Web窗体&#xff08;Default、Default2&#xff09;&#xff0c;在Default窗体上添加两个标准控件&#xff0c;一个TextBox&#xff08;TextBox1&#xff09;、一个Button&#xff08;Button1&#xff09;&#xff0c;设置Button…...

网站建设费发票名称/b2b平台推广

我们当在普通数据转化为响应式数据时,通常会使用ref reactive 进行数据的响应处理 即红色线的转化 但是有时我们还需要进绿色线的转化 即响应数据转化成普通数据 使用toRaw进行对响应对象的转化为普通对象 注意:toRaw只能对reactive的响应进行转化为普通数据, ref 类型无法…...

网站移动端做pc端的301跳转/网站快速收录付费入口

上一博文 NodeJS 实战(二) - 聊天室① 介绍和实现聊天室静态资源的架构&#xff0c; 这一次来加入真正的实时聊天功能吧。 在server.js需要加入新的模块&#xff0c;后续会来定义这个模块&#xff0c;这个模块是基于socket.io主要是用来支持 var chatServer require(./lib/cha…...

网站机房建设/网站查询访问

CentOS 8下默认防火墙FirewallD操作实践 操作环境 自用腾讯云服务器 CentOS Linux release 8.0.1905 (Core) FirewallD 0.6.3 准备工作 了解FirewallD命令使用方法 [rootVM-0-15-centos /]# firewall-cmd -h [rootVM-0-15-centos /]# firewall-cmd --help全部使用方法见本文…...

手机app免费制作/合肥seo推广公司

表哥本科毕业后留到北京工作了。。他大学时候的女友今年研究生毕业也参加工作了。。一天&#xff0c;表哥接到她的邀请&#xff0c;去她家玩。。这女孩子还单身呢&#xff0c;至少她给表哥是这么说的&#xff0c;鉴于此&#xff0c;表哥就去了她家。。表哥一个人在客厅看电视&a…...