基于ElementUI二次封装弹窗组件

news2025/1/21 22:08:14

效果:

基于elementui弹窗的二次封装

一、自定义内容类型弹窗

<!-- 
  title:对话框的标题
  confirmLoading:当前是否处于提交中
  titleCenter:对话框标题居中方式
  footerCenter:底部按钮的对其方式
  visible:是否显示弹窗
  width:设置对话框的宽度
  beforeClose:允许您指定在对话框关闭之前将调用的函数
  closeOnClickModal:确定单击对话框外部(在模态叠加层上)是否会关闭对话框
  center:控制对话框是否在屏幕中央
  customClass:允许您为对话框指定自定义类。此类可用于将自定义样式应用于对话框
  showFooter:确定是否显示带有“取消”和“确认”按钮的默认页脚
 -->
<template>
  <el-dialog
    :visible.sync="dialogVisible"
    :width="width"
    :before-close="handleBeforeClose"
    :close-on-click-modal="closeOnClickModal"
    :center="center"
    :custom-class="customClass"
    :show-close="false"
  >
    <div
      slot="title"
      :style="{'textAlign': titleCenter,'font-size':'16px','font-weight':'bold'}"
    >
      <span>{{title}}</span>
    </div>
    <slot></slot>
    <div slot="footer" v-if="showFooter" :style="{'text-align': footerCenter}" class="dialog-footer">
      <el-button class="cancel-btn" @click="handleCancel" size="small">取消</el-button>
      <el-button class="primary-btn" type="primary"  :loading="confirmLoading" @click="handleConfirm" size="small"
        >{{ confirmLoading ? "提交中" : "确  定" }}</el-button
      >
    </div>
  </el-dialog>
</template>

<script>
export default {
  name:"hsk-dialog",
  props: {
    title: { //对话框的标题
      type: String,
      default: "",
    },
    confirmLoading:{  //当前是否处于提交中
      type: Boolean,
      default: false,
    },
    titleCenter:{  //对话框标题居中方式
      type: String,
      default: "center",
    },
    footerCenter:{ //底部按钮的对其方式
      type: String,
      default: "center",
    },
    visible: { //是否显示弹窗
      type: Boolean,
      default: false,
    },
    width: { //设置对话框的宽度
      type: String,
      default: "400px",
    },
    beforeClose: { //允许您指定在对话框关闭之前将调用的函数
      type: Function,
      default: null,
    },
    closeOnClickModal: { //确定单击对话框外部(在模态叠加层上)是否会关闭对话框
      type: Boolean,
      default: true,
    },
    center: { //控制对话框是否在屏幕中央 ( true) 或不在屏幕中央 ( false)。
      type: Boolean,
      default: true,
    },
    customClass: {  //允许您为对话框指定自定义类。此类可用于将自定义样式应用于对话框
      type: String,
      default: "",
    },
    showFooter: { //确定是否显示带有“取消”和“确认”按钮的默认页脚
      type: Boolean,
      default: true,
    },
  },
  data() {
    return {
      dialogVisible: this.visible,
    };
  },
  watch: {
    visible(newValue) {
      this.dialogVisible = newValue;
    },
    dialogVisible(newValue) {
      this.$emit("update:visible", newValue);
    },
  },
  methods: {
    handleBeforeClose(done) {
      if (this.beforeClose) {
        this.beforeClose(done);
      } else {
        done();
      }
    },
    handleCancel() {
      // this.$emit('update:visible', false);
      this.dialogVisible = false;
      this.$emit("cancel");
    },
    handleConfirm() {
      if (!this.confirmLoading) {
        // this.dialogVisible = false;
        this.$emit("confirm");
      }
      
    },
  },
};
</script>

<style scoped>
/* Add your custom styles here */
 /deep/.el-dialog__body{
  padding: 30px 55px !important;
}
.dialog-footer {
  text-align: right;
  margin-top: 10px;
}
.el-openDialog__header {
  margin-bottom: 10px;
}
.el-dialog__footer{
  margin-bottom: 31px;
}
.cancel-btn{
  width: 80px;
  height: 36px;
  background: #FFFFFF;
  border-radius: 2px 2px 2px 2px;
  opacity: 1;
  box-sizing: border-box;
  border: 1px solid #707070;
}
.primary-btn{
  margin-left:20px;
  width: 80px;
  height: 36px;
  background: #0759C4;
  box-sizing: border-box;
  border-radius: 2px 2px 2px 2px;
}
</style>

父组件使用

<template>
  <div>
    <el-button type="text" @click="openDialog">弹出窗口</el-button>
    <!-- <el-button @click="openDialog">打开对话框</el-button> -->
    <hsk-dialog
      :visible.sync="dialogVisible"
      title="自定义对话框"
      :width="width"
      :before-close="beforeCloseHandler"
      :close-on-click-modal="false"
      :center="false"
      :showFooter="true"
      custom-class="custom-dialog"
      :show-footer="false"
      @confirm="handleConfirm"
      @cancel="handleCancel"
      :confirm-loading="confirmLoading"
    >
      自定义内容及表单
    </hsk-dialog>
  </div>
</template>

<script>
export default {
  components: {
    // hskDialog
  },
  data() {
    return {
      confirmLoading: false,
      dialogVisible: false,
      width: "400px",
    };
  },
  methods: {
    openDialog() {
      this.dialogVisible = true;
    },
    beforeCloseHandler(done) {
      this.$message.info("点击了“X”操作");
      done();
    },
    handleConfirm() {
      // this.$message.success('点击了确定按钮');
      this.confirmLoading = true;
      this.$message.success("点击了确定按钮");
      setTimeout(() => {
        this.confirmLoading = false;
      }, 1000);
    },
    handleCancel() {
      this.$message.info("点击了取消按钮");
    }
  },
};
</script>
<style>
.a {
  text-align: left;
  margin-top: 0;
}
.codebox{
  line-height: 24px;
}
</style>

二、删除提示类型弹窗封装

/* eslint-disable no-unused-vars */
/* eslint-disable no-undef */
import {MessageBox} from "element-ui"
import "./styles/pop-up.css"
export function hskMsgbox (h, title,value,iconClass='',iconColor='') {
  const newDatas = [];
  const confirmText = Array.isArray(value) ? [...value] : [value];
  if(value.length===1){
    newDatas.push(h('i', { class: iconClass,style:'color:'+iconColor+';float: left;margin-right:5px;font-size:24px;'}),h('div', { style: 'padding-left:-6px;text-align: left;font-size: 14px;font-weight:bold;' }, confirmText[0]));
  }else{
    for (const i in confirmText) {
        if(i==='0'){
          newDatas.push(h('div', { class: iconClass,style:'color:'+iconColor+';float: left;margin-right:5px;font-size:24px;'}),h('div', { style: 'padding-left:-6px;text-align: left;font-size: 14px;font-weight:bold;' }, confirmText[i]));
        }else{
          newDatas.push(h('div', { style: 'padding-left:-6px;text-align: left;font-size: 12px' }, confirmText[i] ));
        }
    }
  }
  
   const promiseconfirm = new Promise((resolve, reject) => {
    MessageBox.confirm('Tip', {
      title: title,
      message:h('p', {style:"text-align: left;"}, [
        newDatas
      ]), 
      showCancelButton: true,
      confirmButtonText: "确定",
      cancelButtonText: "取消",
      center: true
    }).then(() => {
      resolve(true)
    }).catch(() => {
      resolve(false)
    })
  })
  return promiseconfirm
}

删除提示类型弹窗样式文件

.el-message-box__title {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
}
.el-message-box__header{
  padding-bottom: 6px !important;
  padding-top: 23px !important;
}
.el-message-box--center{
  padding-bottom:25px !important;
}

父组件使用

<template>
  <div>
    <el-button type="text" @click="deleteClick">删除样式一</el-button>
    <br />
    <el-button type="text" @click="deleteClick2">删除样式二</el-button>
    <br />
    <el-button type="text" @click="deleteClick3">删除样式三</el-button>
    <br />
    <el-button type="text" @click="deleteClick4">删除样式四</el-button>
  </div>
</template>

<script>
import { hskMsgbox } from "@/package/commonUtils.js";
export default {
  components: {
  },
  data() {
    return {
    };
  },
  methods: {
    //删除
    async deleteClick() {
      // confirmANewline
      const h = this.$createElement;
      // let abc = 11
      let confirmText1 = [
        `是否删除数据字典?`,
        // `删除后,数据无法找回,请谨慎操作。`,
      ];
      let a = await hskMsgbox(
        h,
        "删除数据字典",
        confirmText1
      );
      console.log("a", a);
    },
    //删除样式二
    async deleteClick2() {
      // confirmANewline
      const h = this.$createElement;
      // let abc = 11
      let confirmText1 = [
        `是否删除数据字典?`,
        `删除后,数据无法找回,请谨慎操作。`,
      ];
      let a = await hskMsgbox(
        h,
        "删除数据字典",
        confirmText1
      );
      console.log("a", a);
    },
    async deleteClick3() {
      // confirmANewline
      const h = this.$createElement;
      // let abc = 11
      let confirmText1 = [
        `是否删除数据字典?`,
      ];
      let a = await hskMsgbox(
        h,
        "删除数据字典",
        confirmText1,
        "el-icon-warning",
        "red"
      );
      console.log("a", a);
    },
    async deleteClick4() {
      // confirmANewline
      const h = this.$createElement;
      // let abc = 11
      let confirmText1 = [
        `是否删除数据字典?`,
        `删除后,数据无法找回,请谨慎操作。`,
      ];
      let a = await this.hskMsgbox(
        h,
        "删除角色",
        confirmText1,
        "el-icon-warning",
        "#E6A23C"
      );
      console.log("a", a);
    },
  },
};
</script>
<style>
</style>

提示弹窗取消和确认返回的是true和false

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

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

相关文章

Scrapy使用案例——爬取豆瓣Top 250电影数据

文章目录 什么是Scrapy&#xff1f;创建Scrapy项目编写Scrapy Spider创建Item类配置数据存储运行Scrapy爬虫处理常见问题结论Python技术资源分享1、Python所有方向的学习路线2、学习软件3、入门学习视频4、实战案例5、清华编程大佬出品《漫画看学Python》6、Python副业兼职与全…

【ArcGIS微课1000例】0082:地震灾害图件制作之DEM晕渲图(山体阴影效果)

以甘肃积石山县6.2级地震为例,基于震中100km范围内的DEM数据,制作数字高程模型山体阴影晕渲图。 文章目录 一、效果展示二、实验数据三、晕渲图制作一、效果展示 基于数字高程模型制作的山体阴影晕渲图如下所示: 二、实验数据 本试验所需要的数据包括: 1. 震中位置矢量数…

正确的认识 字节码文件

上一篇中认识了JVM的基本组成&#xff0c;我们说JVM只认识字节码文件。那么在字节码文件进入JVM之前&#xff0c;我们先认识了解字节码文件长什么样&#xff0c;我们作为工程师不需要去死扣底层的理论知识&#xff0c;但是我们只是需要正确的打开字节码文件 知道里面有哪些部分…

暗光增强——Zero-DCE网络推理测试

目录 一、Zero-DCE方法1.1 网络优点1.2 网络适用场景1.3 网络不适用场景 二、源码包三、测试四、测试结果五、推理速度六、总结 一、Zero-DCE方法 Zero-DCE&#xff08;Zero-Reference Deep Curve Estimation&#xff09;是一种用于低光照增强的网络。 1.1 网络优点 无需参考…

华为商城秒杀时加密验证 device_data 的算法研究

前言 之前华为商城放出 Mate60 手机时, 想给自己和家人抢购一两台&#xff0c;手动刷了好几天无果后&#xff0c;决定尝试编写程序&#xff0c;直接发送 POST 请求来抢。通过抓包和简单重放发送后&#xff0c;始终不成功。仔细研究&#xff0c;发现 Cookie 中有一个名为 devic…

提升效率:使用注解实现精简而高效的Spring开发

IOC/DI注解开发 1.0 环境准备1.1 注解开发定义bean步骤1:删除原XML配置步骤2:Dao上添加注解步骤3:配置Spring的注解包扫描步骤4&#xff1a;运行程序步骤5:Service上添加注解步骤6:运行程序知识点1:Component等 1.2 纯注解开发模式1.2.1 思路分析1.2.2 实现步骤步骤1:创建配置类…

基于ssm的教师上课系统+vue论文

目 录 目 录 I 摘 要 III ABSTRACT IV 1 绪论 1 1.1 课题背景 1 1.2 研究现状 1 1.3 研究内容 2 2 系统开发环境 3 2.1 vue技术 3 2.2 JAVA技术 3 2.3 MYSQL数据库 3 2.4 B/S结构 4 2.5 SSM框架技术 4 3 系统分析 5 3.1 可行性分析 5 3.1.1 技术可行性 5 3.1.2 操作可行性 5 3…

117基于matlab的短时傅里叶变换(STFT)、小波变换(WT)、同步压缩变换(SST)、瞬态提取变换(TET)进行时频分析

基于matlab的短时傅里叶变换&#xff08;STFT&#xff09;、小波变换&#xff08;WT&#xff09;、同步压缩变换&#xff08;SST&#xff09;、瞬态提取变换&#xff08;TET&#xff09;进行时频分析。程序已调通&#xff0c;可直接运行。 117时频分析短时傅里叶变换 (xiaohong…

eve环境虚拟机和电脑如何传送文件

一.桥接 &#xff08;实现电脑和虚拟机在同一网段&#xff09; 虚拟机上网盘设置 二.属性---文件共享设置 1打开属性&#xff0c;点击共享 2.添加共享人为全部人&#xff0c;并修改权限为读写模式 3.点击高级共享&#xff0c;选定此文件夹 4.点击网络和共享中心&#xff0c;划…

c语言:把二维数组降至一维|练习题

一、题目 把二维数组降为一围数组 如图&#xff1a; 二、代码截图【带注释】 三、源代码【带注释】 #include <stdio.h> int main() { int arr2[3][3];//设置二维数组 int arr1[10];//设置一维数组 int z0;//一维数组自增量 printf("输入一个二维数…

【源码】-MyBatis-如何系统地看源码

写在前面 前段时间做过一个项目&#xff0c;期间用到了动态数据源dynamic-datasource&#xff0c;经历了dbcp2的数据库连接池没有生效到排查定位、MyBatis多种数据库产品兼容、手写MyBatis拦截器等事情。 花费了好久&#xff0c;一直在打磨这篇文章&#xff08;不知道花费这么长…

DevEco Studio4.0 Beta2集成ArkUI-X(开发鸿蒙,安卓.ios应用)/ACE Tools脚手架

ArkUI-X简介 ArkUI-X进一步将ArkUI扩展到了多个OS平台&#xff1a;目前支持OpenHarmony、HarmonyOS、Android、 iOS&#xff0c;后续会逐步增加更多平台支持。开发者基于一套主代码&#xff0c;就可以构建支持多平台的精美、高性能应用 该框架对应的IDE版本为 4.0 Beta2 &…

代码随想录刷题 | Day1

今日学习目标 一、基础 数组 array类 模板类vector 数组是存放在连续内存空间上的相同类型数据的集合。 数组可以方便的通过下标索引的方式获取到下标下对应的数据。 需要两点注意的是 数组下标都是从0开始的。 数组内存空间的地址是连续的 而且大家如果使用C的话&…

Leetcode的AC指南 —— 哈希法/双指针:15. 三数之和

摘要&#xff1a; Leetcode的AC指南 —— 15. 三数之和。题目介绍&#xff1a;给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且…

腱鞘囊肿,不就是个水泡嘛?不!可别小瞧了它

腱鞘囊肿&#xff0c;很多人并不陌生&#xff0c;因为它的发病率比较高&#xff0c;不少人都有过腱鞘囊肿的经历。 有的人觉得不美观&#xff0c;有的人害怕癌变&#xff0c;有的人担心影响功能能&#xff0c;有的人经医生用力挤破好转&#xff0c;有的人经穿刺抽液治愈&#x…

使用element中el-cascader级联选择器动态懒加载以及回显 (单选)

<template><!-- 新增||修改弹框 --><el-dialog :close-on-click-modal"false" :close-on-press-escape"false" :title"title" :visible.sync"open"width"800px" append-to-body><el-form ref"for…

Unity | 快速修复Animation missing错误

目录 一、背景 二、效果 三、解决办法 一、背景 最近在做2D 骨骼动画相关的Demo&#xff0c;我自己使用Unity引擎进行骨骼绑定并创建了anim后&#xff0c;一切正常&#xff0c;anim也能播放。但是昨天我修改Obj及子物体的名称&#xff08;由中文改为英文&#xff0c;如&…

RabbitMQ 核心概念(交换机、队列、路由键),队列类型等介绍

RabbitMQ 核心概念(交换机、队列、路由键)&#xff0c;队列类型等介绍 RabbitMQ 是一个消息队列系统&#xff0c;它的核心概念包括交换机&#xff08;Exchange&#xff09;、队列&#xff08;Queue&#xff09;和路由键&#xff08;Routing Key&#xff09;&#xff0c;它们一起…

OpenStack云计算(-) 简介与部署Keystone

一.OpenStack简介 什么是云计算:云计算是一种按使用量付费的模式,这种模式提供可用的、便捷的、按需的网络访问,进入可配置的计算资源共享池(资源包括网络,服务器,存储,应用软件,服务) 云计算所包含的几个层次服务&#xff1a; SaaS ( Software as a Service ) :把在线软件作…

LLM提示词工程学习_Day01

LLM提示词工程学习_Day01 安装学习环境基础Conda环境安装安装Python安装所需的包Jupyter Notebook 安装获取OpenAI API KEY&#xff0c;并写入工程目录里的.env文件进入Jupyter&#xff0c;先跑一段代码 安装学习环境 基础Conda环境安装 conda环境安装&#xff0c;miniconda也…