Element UI MessageBox 增加第三个按钮(DOM Hack 方案)

Element UI 的 MessageBox 官方只支持 确认 / 取消 两个按钮。

如果必须继续使用 MessageBox 且 UI 上需要 3 个按钮,只能通过 DOM hack 实现。

⚠️ 注意:此方案非官方支持,适合老项目或临时需求。

实现思路

  1. 通过 customClass 给 MessageBox 添加唯一类名

  2. 弹框渲染完成后,手动向按钮容器 .el-message-box__btns 中插入一个按钮

  3. 在按钮点击事件中执行业务逻辑并关闭弹框

示例代码

javascript 复制代码
this.$msgbox({
  title: '操作确认',
  message: '请选择你的操作',
  showCancelButton: true,
  confirmButtonText: '提交',
  cancelButtonText: '取消',
  customClass: 'three-btn-msgbox'
}).then(() => {
  this.submit()
}).catch(() => {
  this.cancel()
})

this.$nextTick(() => {
  const btnBox = document.querySelector(
    '.three-btn-msgbox .el-message-box__btns'
  )
  if (btnBox && !btnBox.querySelector('.extra-btn')) {
    const btn = document.createElement('button')
    btn.className = 'el-button el-button--warning extra-btn'
    btn.innerText = '保存'
    btn.onclick = () => {
      this.save()
      document
        .querySelector('.three-btn-msgbox .el-message-box__close')
        .click()
    }
    btnBox.insertBefore(btn, btnBox.firstChild)
  }
})

风险说明

  1. 依赖 Element UI 内部 DOM 结构

  2. 框架升级可能导致失效

  3. 不适合封装为公共组件

  4. 极易污染其他的弹框

总结

  1. MessageBox 想要 3 个按钮,只能 hack;
  2. 能用 el-dialog 的场景,永远优先 el-dialog。
  3. 如果不是必须继续使用 MessageBox,还是推荐用 el-dialog 实现此需求。
相关推荐
WooaiJava7 分钟前
AI 智能助手项目面试技术要点总结(前端部分)
javascript·大模型·html5
LYFlied11 分钟前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
爱喝白开水a27 分钟前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
Never_Satisfied27 分钟前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
董世昌4127 分钟前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
B站_计算机毕业设计之家41 分钟前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
WeiXiao_Hyy1 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
吃杠碰小鸡1 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone2 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09012 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js