vue2 实战:动态组件,异步组件

需求:

根据不同类型,显示不同页面

原始代码,菜逼写法

<template>
<!-- 弹窗插件 -->
<el-dialog :title="title" :visible.sync="openExchange" width="700px" append-to-body :before-close="handleClose" :close-on-click-modal="false"><div v-if="this.options.layout=='exchange'" ><dialog-exchange :options = this.options /></div><div v-else-if="this.options.layout=='webpage'" ><dialog-webpage :options = this.options /></div><div v-else-if="this.options.layout=='annex'" ><dialog-annex :options = this.options /></div><div slot="footer" class="dialog-footer"><el-button type="primary" @click="updateData">确 定</el-button><el-button @click="handleClose">取 消</el-button></div>
</el-dialog>
</template><script>
import dialogExchange from './components/dialogExchange'
import dialogWebpage from './components/dialogWebpage'
import dialogAnnex from './components/dialogAnnex'export default {components: {dialogExchange,dialogWebpage,dialogAnnex,},data() {openExchange: false,title: "",options: [],},
}
</script>

阅读过官方文档,了解到动态组件和异步组件注册

采用动态注册组件,更新后代码

<template>
<!-- 弹窗插件 -->
<el-dialog :title="title" :visible.sync="openExchange" width="700px" append-to-body :before-close="handleClose" :close-on-click-modal="false"><!-- 使用 component --><component:is="this.options.layout":options="this.options"/></el-dialog>
</template><script>export default {components: {},data() {openExchange: false,title: "",options: [],componentsType: [{ name:"exchange", value: './components/dialogExchange' },{ name:"webpage", value: './components/dialogWebpage' },{ name:"annex", value: './components/dialogAnnex' },]},created() {this.registerComponent();},methods: {// 注册组件async registerComponent() {this.componentsType.forEach(element => {if (!this.$options.components[element.name]) {try {this.$options.components[element.name] = (resolve) => require([`${element.value}`], resolve);} catch (error) {this.$modal.alertError("注册组件发生异常:" + error);console.warn("注册组件发生异常:" + error);}}});},}
}
</script>

后续维护只要往componentsType添加组件类型和地址就可以了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/753791.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Unity】Transform、Rigidbody、CharacterController移动

前言 在使用Unity开发的时候&#xff0c;移动是最最基础的一个需求&#xff0c;我来给大家简单的讲一下Unity中的几种常见的移动方法。 1.Transform移动 Transform移动就是修改物体的position ①修改位置 这里要注意&#xff1a;坐标分为世界坐标和本地坐标 //将物体的世界坐…

如何解决网络中IP地址发生冲突故障?

0、前言 本专栏为个人备考软考嵌入式系统设计师的复习笔记&#xff0c;未经本人许可&#xff0c;请勿转载&#xff0c;如发现本笔记内容的错误还望各位不吝赐教&#xff08;笔记内容可能有误怕产生错误引导&#xff09;。 1、个人IP地址冲突解决方案 首先winR&#xff0c;调出…

关于 闰年 的小知识,为什么这样判断闰年

闰年的规定&#xff1a; 知道了由来&#xff0c;我们就可以写程序来判断&#xff1a; #include <stdio.h> int main() {int year, leap;scanf("%d",&year);if((year%4 0 && year%100 ! 0) || year%400 0)leap 1;else leap 0;if(leap) printf(…

【Linux下qt软件安装打包附带问题: dpkg: error processing package xxxx +解决方式+自我尝试+记录】

【Linux下qt软件安装打包附带问题&#xff1a; dpkg: error processing package xxxx 解决方式自我尝试记录】 1、前言2、实验环境3、问题说明4、我的努力与查到解决的方式&#xff08;1&#xff09;补充两个文件&#xff0c;让软件正常执行&#xff08;2&#xff09;尝试修复d…

29.网络游戏逆向分析与漏洞攻防-网络通信数据包分析工具-数据推测功能的算法实现

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果 内容参考于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;28.数据推测结果…

智慧公厕对于智慧城市管理的意义

近年来&#xff0c;智慧城市的概念不断被提及&#xff0c;而智慧公厕作为智慧城市管理的重要组成部分&#xff0c;其在监测、管理和养护方面发挥着重要的作用。智慧公厕不仅是城市市容提升的重要保障&#xff0c;还能提升城市环境卫生管理的质量&#xff0c;并有效助力创造清洁…

springBoot项目,无配置中心,怎么实现类似功能

实现EnvironmentPostProcessor import cn.hutool.http.HttpUtil; import org.springframework.boot.SpringApplication; import org.springframework.boot.env.EnvironmentPostProcessor; import org.springframework.boot.env.YamlPropertySourceLoader; import org.springfr…

用electron将vue项目打包成.exe文件【保姆级教程】

用electron将vue项目打包成.exe文件【保姆级教程】 说明&#xff1a; vue2项目&#xff0c;使用的vue-element-admin框架&#xff0c;用electron打包成.exe文件。 1、新建一个文件夹&#xff0c;然后右键打开终端或者cd到这个目录。执行下面的命令&#xff08;最好确认一下gith…

c语言文件操作(中)

目录 1. 文件的顺序读写1.1 顺序读写函数1.2 顺序读写函数的原型和介绍 结语 1. 文件的顺序读写 1.1 顺序读写函数 函数名功能适用于fgetc字符输入函数所有输出流fputc字符输出函数所有输出流fgets文本行输入函数所有输出流fputs文本行输出函数所有输出流fscanf格式化输入函数…

AI+权重衰退

AI权重衰退 1权重衰退2代码实现 2丢弃法 1权重衰退 AI权重衰退是指在人工智能&#xff08;AI&#xff09;领域中的一种技术或方法&#xff0c;用于训练机器学习模型时对权重进行惩罚或调整&#xff0c;以避免过拟合现象的发生。 在机器学习中&#xff0c;过拟合是指模型在训练…

红队笔记7--Web机器为Linuxdocker逃逸

其实&#xff0c;不知道大家有没有想过&#xff0c;我们之前练习的都是web机器是windows的版本&#xff0c;但是其实&#xff0c;在现实生活中&#xff0c;服务器一般都是Linux的版本&#xff0c;根本不可能用到windows的版本 那么如果是Linux的话&#xff0c;我们就有很多的困…

恒创科技:什么是BGP线路服务器?BGP机房的优点是什么?

在当今的互联网架构中&#xff0c;BGP(边界网关协议)线路服务器和BGP机房扮演着至关重要的角色。BGP作为一种用于在自治系统(AS)之间交换路由信息的路径向量协议&#xff0c;它确保了互联网上的数据能够高效、准确地从一个地方传输到另一个地方。那么&#xff0c;究竟什么是BGP…

车载电子电器架构 - 网络拓扑

车载电子电器架构 - 网络拓扑 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师 (Wechat:gongkenan2013)。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 本就是小人物,输了就是输了,不要在意别人怎么看自己。江湖一碗茶,喝完再挣扎,出门靠…

单点登录:一把钥匙开启所有门

单点登录&#xff08;SSO&#xff09;技术&#xff0c;就像是一把开启企业数字化大门的钥匙&#xff0c;让用户一次登录&#xff0c;随处访问&#xff0c;极大地提升了工作效率和用户体验。具体到技术实现上&#xff0c;当用户首次登录时&#xff0c;SSO系统会进行认证&#xf…

Linux权限维持后门及应急响应

本次应急响应实验用kali和centos7来充当攻击机和靶机 kali&#xff1a;192.168.10.130 centos7&#xff1a;192.168.10.155 前提&#xff1a; 用kali连接到centos7上面ssh root192.168.10.155 一、SSH软链接 任意密码登录即可发现程度&#xff1a;|||||| ln -sf /usr/sbi…

CCleaner清理软件好不好 CCleaner怎么清理运行内存

CCleaner是一款使用简单&#xff0c;功能强大的电脑清理软件&#xff0c;该软件价格低廉&#xff0c;即使是学生也可以承担。那么这个软件究竟怎么样&#xff1f;可以怎么使用呢&#xff1f;下面就来带大家看一看CCleaner清理软件好不好&#xff0c;CCleaner怎么清理运行内存。…

Java-SpringAop 编程式事物实现

SpringAop 编程式事物实现 1. 数据库事物特性 原子性 多个数据库操作是不可分割的&#xff0c;只有所有的操作都执行成功&#xff0c;事物才能被提交&#xff1b;只要有一个操作执行失败&#xff0c;那么所有的操作都要回滚&#xff0c;数据库状态必须回复到操作之前的状态 …

redis-操作数据库

0 序言 一个Redis服务器可以包含多个数据库。在默认情况下&#xff0c;Redis服务器在启动时将会创建16个数据库&#xff1a;这些数据库都使用号码进行标识&#xff0c;其中第一个数据库为0号数据库&#xff0c;第二个数据库为1号数据库&#xff0c;而第三个数据库则为2号数据库…

week08day01(power bi)

一 . 同期指标&#xff08;与之前的对比&#xff09; #同期销售额 -- SAMEPERIODLASTYEAR : 自动返回上一年度 的 同一日期销售额 PY CALCULATE([Core 销售额],SAMEPERIODLASTYEAR(维度 日期时间表[日期]) )-- 1.财务想法 : 2019年 和 2018年对比,但是2019年的数据截止到8/20…

用pako.js压缩字符串,如何在后端用java解开?

背景&#xff1a;项目链路为腾讯clb->Ingress(nginx)->项目服务,腾讯的Ingress对header请求头最大值为256K&#xff0c;无法加大&#xff0c;由于业务配置数据增加&#xff0c;此问题诟病已久&#xff0c;于是想着压缩打请求头数据后再请求&#xff0c;从而解决请求头大的…