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

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

ruisui884个月前 (02-03)技术分析21

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


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



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

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/778.html

标签: vue url传参
分享给朋友:

“VUE前端编程:如何通过全局对话框引入动态组件” 的相关文章

2024年10 大 Linux 桌面发行版推荐

年已过半,现在是探究 2024 年最流行的 Linux 发行版的最佳时机。Linux 是一个开源操作系统,构建在 Linux 内核上,并集成了 GNU shell 实用程序、桌面环境、应用程序、包管理系统。由于其通用性、安全性、用户友好性和多样性,它的受欢迎程度超过了其他操作系统。在本文中,我们将从...

10分钟搞定gitlab-ci自动化部署

gitlab-ci 是持续集成工具/自动化部署工具,类似 jenkins。持续集成 是将代码集成到共享存储库并尽可能早地自动构建/测试每个更改的实践 - 通常一天几次。概述在编码完成时都会进行打包发布过程,如果每次都手动操作这一步骤就会浪费时间,效率低下。所以就有了持续集成。准备事项请提前安装以下软...

快速掌握 Git:程序员必会的版本控制技巧

在现代软件开发中,版本控制系统(VCS)是开发人员不可或缺的工具。无论是个人项目,还是多人协作的团队开发,良好的版本控制都能确保代码管理的高效性与稳定性。而在版本控制系统中,Git 凭借其分布式、灵活性和高效性,成为了最流行的工具之一。几乎所有的开发团队都在使用 Git 来管理代码版本、协作开发和追...

抖音 Android 性能优化系列:启动优化实践

启动性能是 APP 使用体验的门面,启动过程耗时较长很可能使用户削减使用 APP 的兴趣,抖音通过对启动性能做劣化实验也验证了其对于业务指标有显著影响。抖音有数亿的日活,启动耗时几百毫秒的增长就可能带来成千上万用户的留存缩减,因此,启动性能的优化成为了抖音 Android 基础技术团队在体验优化方向...

USB电池充电基础:应急指南

USB为便携设备供电与其串行通信功能一样,已经成为一种标准应用。如今,USB 供电已经扩展到电池充电、交流适配器及其它供电形式的应用。应用的普及带来的一个显著效果是便携设备的充电和供电可以互换插头和适配器。因此,相对于过去每种装置都采用专用适配器的架构相比,目前的解决方案允许采用多种电源进行充电。毋...

一起学Vue:路由(vue-router)

前言学习vue-router就要先了解路由是什么?前端路由的实现原理?vue-router如何使用?等等这些问题,就是本篇要探讨的主要问题。vue-router是什么路由是什么?大概有两种说法:从路由的用途上来解释路由就是指随着浏览器地址栏的变化,展示给用户的页面也不相同。从路由的实现原理上来解释路...