-
VUE前端编程:如何通过全局对话框引入动态组件
- 网站名称:VUE前端编程:如何通过全局对话框引入动态组件
- 网站分类:技术文章
- 收录时间:2025-06-09 21:09
- 网站地址:
“VUE前端编程:如何通过全局对话框引入动态组件” 网站介绍
在VUE编程中,经常会遇到对话框,但ElementUI或者是AntD提供的模态框一是要在每个页面中写Dialog,一个是对Dialog中含有的组件定制能力有限。因此,这里提供一个全局对话框并动态引入组件,从而有效地提高系统弹性和减少开发量。好,我们先看一下效果图:
全局对话框
全局对话框的思路其实很简单,就是通过VUE的定义一个全局变量$dialog,并管理和维护一个在DOM中动态增加或删除的节点。
先定义一个Dialog VUE用作展示,动态组件也是写在这里面,后面我们细谈。
如下为定义dialogModel:
import Vue from 'vue';
import dialog from './dialog-box.vue';
let dialogBuilder = Vue.extend(dialog); //刚才定义的的VUE
let dialogModal = (o) =>{
let dialogDom = new dialogBuilder({
el: document.createElement('div'),
})
document.body.appendChild(dialogDom.$el);
//以下是调用环境传给Dialog的参数
dialogDom.title=o.title;
dialogDom.component=o.component; //传入动态组件
dialogDom.position=o.position;
dialogDom.widthOf=o.widthOf;
dialogDom.heightOf=o.heightOf;
dialogDom.params=o.params;
dialogDom.value=o.value;
dialogDom.enableFooter=o.enableFooter;
dialogDom.footComponent=o.footComponent;
dialogDom.footValue=o.footValue;
}
export default dialogModal;
在main.js中引入:
import dialog from '@/hayoo/chameleon/dialogs/dialog'
Vue.prototype.$dialog=dialog
...
好,只要在需要使用Dialog的地方进行配置就可以了,如上例的新增资产:
动态组件
接下来我们看一下动态组件,在开始的dialog VUE组件中,我们引入动态组件Component,在该例中,我引入了两个组件,一个是内容,一个是固化在底部的Footer,其原理都是一样的:
上例中,注意动态组件上的参数,这里指定的参数名如果和我们自定义的属性名一致,这里会自动传值,如果没有对应的属性名,那将会进入组件的$attrs中,这里注意一下。另外,组件里面可以通过触发@onQuit事件和dialog的关闭机制链接,实现定制组件关闭弹窗。
组件引入通过Component的is属性完成,在dialog Vue组件中,定义如下:
定义组件按我们正常引入即可:
调用组件的参数在指定dialog时可以一起指定,但注意这里的传参实际上是dialogModal完成的,因此,所有的参数必须在dialogModal中都要设置。
通讯机制
到这里基本上就完成了,接下来我们看动态组件和调用环境的通讯机制,一开始想用Vuex的,但发现dialog预警识别不到vuex,所以我偷懒用了EventBus,大家这里可以自己研究一下更好的通讯机制。如刚才的例子里,我在creator中点击保存时Axios的回调函数中,我做了关闭对话框的事件和EventBus上发布刷新列表的事件。
列表中做事件订阅,就可以完成数据的通讯了:
上边的例子是一些比较简单的经验之谈,感兴趣的朋友可以看一下,有什么问题欢迎随时交流,学无止境,大家一起努力提高。
- 上一篇:一文讲透支付宝沙箱的基本应用
- 下一篇:网络安全之从原理看懂XSS
更多相关网站
- 前端案例·程序员的浪漫:流星雨背景
- 8个非常实用的Vue自定义指令
- 前端必看!10 个 Vue3 救命技巧,解决你 90% 的开发难题?
- 是时候使用iframe延迟加载来提升LCP!
- 10个Vue开发技巧「实践」
- JavaScript 事件——“事件类型”中“UI事件”的注意要点
- 网络安全与防范
- vue下载excel文件方法
- 前端分享-少年了解过iframe么
- JavaScript代码嵌入HTML的方法、及两者的在执行流程上的细微区别
- 判断变量是否为数组
- JS如何判断文字被ellipsis了?
- ES6页面假死原因及解决方案
- 网络安全之从原理看懂XSS
- 一文讲透支付宝沙箱的基本应用
- Js基础3:节点创建
- 32个手写JS,巩固你的JS基础(面试高频)
- Chrome 扩展开发:哪种实现方式适合您的需求
- 最近发表
-
- 联想推出 IdeaPad 14s / 15s:均为 3399 元,运行 Win11 系统
- 顶配版ThinkPad X1 Carbon评测
- 联想ThinkPad X1 Carbon评测
- lenovo联想 拯救者-14 加装ssd、内存及win10转移到ssd经验谈
- 联想发布新款耳机鼠标等配件:专为ThinkPad X1设计
- 杜比全景音体验,联想K4 Note在印度正式发布
- 3099 元起,联想推出 IdeaPad 15:约10小时续航,预装 Win11系统
- 联想拯救者Y70、小新Pad Pro 2022发布丨拯救者Y70测评体验
- 千元可定制!联想K4 Note印度发布:杜比全景音体验
- 声临其境 联想TAB2 A10平板联手杜比
- 标签列表
-
- serv-u 破解版 (6)
- 极域电子教室2009 (6)
- 6300主题下载 (1)
- oracle11204下载 (1)
- c++论坛 (14)
- huaweiupdateextractor (4)
- thinkphp6下载 (7)
- 前端论坛 (11)
- mysql 时间索引 (13)
- mydisktest_v298 (35)
- unlocker208 (1)
- sql 日期比较 (33)
- document.appendchild (35)
- 头像打包下载 (35)
- 二调符号库 (23)
- oppoa5专用解锁工具包 (8)
- acmecadconverter_8.52绿色版 (25)
- oracle timestamp比较大小 (7)
- chm editor破解版 (7)
- throttlestop防止降频 (9)
- f12019破解 (16)
- 流星蝴蝶剑修改器 (18)
- pygame中文手册 (2)
- 联想杜比音效驱动下载 (10)