当前位置:首页 > 技术文章 > 正文内容

VUE前端编程:如何通过全局对话框引入动态组件

zonemu3个月前 (07-25)技术文章30

在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上发布刷新列表的事件。


列表中做事件订阅,就可以完成数据的通讯了:



上边的例子是一些比较简单的经验之谈,感兴趣的朋友可以看一下,有什么问题欢迎随时交流,学无止境,大家一起努力提高。

相关文章

vue3源码分析——实现组件通信provide,inject

引言<<往期回顾>>vue3源码分析——rollup打包monorepovue3源码分析——实现组件的挂载流程vue3源码分析——实现props,emit,事件处理等vue3源...

程序员项目经理如何调动组员积极性

#这个方法应该很适合程序员都说程序员是比较傲娇,有点小自负(有的是相当,那不叫自负,那是实力的体现好吗),略微呆萌,自尊心偏小强的一类族群。是吗?中招了吗?作为管理好几个组员,要完成一个大项目的项目经...

HTML5培训的学习大纲

第一阶段前端开发基础:1.HTML标签语言(xhtml+html5)行业介绍,本地环境配置,sublime编辑器学习使用,制作html标准模板,css基础,html常用标签(一),html常用标签(二...

解锁无限潜力,在没有数组溢出情况下,掌握Filter公式正确用法

嗨,朋友们!今天我要和大家分享一些关于Filter公式的知识,这将帮助你们解决没有数组溢出情况下的问题。你是否曾经在处理数据时遇到过没有数组溢出的情况?不用担心,因为我将教你一些正确使用Filter公...

Excel中的FILTER函数详细介绍及使用示例

在Excel中处理大量数据时,经常需要根据特定条件筛选出符合条件的数据行或列。这正是Excel的FILTER函数发挥作用的地方。FILTER函数是Excel中一个非常强大的工具,它可以基于一个或多个条...

AOP的实现落地(拦截过滤),一切都要从Servlet说起

一、一切要从Servlet说起1.1什么是ServletServlet(Server Applet),全称是Java Servlet,是提供基于协议请求/响应服务的Java类。在JavaEE中是Ser...