Vue3 中使用 Element Plus 实现自定义按钮的 ElNotification 提示框

在 Vue3 项目中,我们经常会用到 ElNotification 作为消息提醒组件,尤其是在异步操作、任务完成或用户需要交互确认时。然而,Element Plus 默认的 Notification 是非交互式的,不能直接嵌入按钮或事件。

今天我们来实现一个带自定义按钮和点击事件的 Notification 提示框,并且支持手动关闭。

✨ 目标效果

我们希望实现这样的功能:

  • 弹出一个固定的通知框(duration: false
  • 内容中嵌入自定义按钮
  • 点击按钮后执行事件回调,并关闭该通知框

📦 技术栈

  • Vue 3 Composition API
  • Element Plus
  • 渲染自定义内容:h() 渲染函数
  • 引用通知对象:ref + id 进行映射管理

✅ 实现方案

1. 基础代码结构

<script setup lang="ts">
import { ElNotification } from 'element-plus'
import { ref, h } from 'vue'// 存储所有通知实例
const notify = ref<Record<string, any>>({})// 触发通知
const fc = () => {const id = Math.random().toString()const closeNotification = () => {notify.value[id]?.close()delete notify.value[id]}notify.value[id] = ElNotification({type: 'warning',title: '提醒',duration: 0,dangerouslyUseHTMLString: true,message: h('div', [h('p', {}, '消息内容'),h('p',{style: 'width: 250px; display: flex; justify-content: space-between;',},[h('a',{style: 'color: #409EFF; cursor: pointer;',onClick: closeNotification,},'确定'),]),]),})
}
</script>

🔍 核心逻辑说明

关键点说明
notify.value存储所有当前激活的通知框引用,方便后续关闭
Math.random().toString()用作唯一 key 区分多个通知(可换成 UUID)
h()Vue 的渲染函数,用于嵌入 HTML/组件内容
dangerouslyUseHTMLString: trueh() 冲突,写错会无效;这里只是保留展示形式建议使用 h() 就不加它
duration: 0通知不会自动关闭,用户需点击按钮关闭
onClick: closeNotification点击按钮时关闭对应通知框

🧠 可扩展思路

  1. 多个按钮场景

    h('button', { onClick: handleReject }, '拒绝')
    h('button', { onClick: handleAccept }, '接受')
    
  2. 替换为组件
    使用 defineComponent 包一层小组件传给 message

  3. 支持通知唯一性
    通知已存在就不再重复弹出,避免重复提醒

  4. 封装为 composable

    const useNotification = () => {const notifyMap = ref({})const show = (opts: { message: string; onClick: Fn }) => { ... }return { show }
    }
    

🧪 实际应用场景

  • 后台审批通知:“你有一条待处理任务”
  • 导出提示:“导出任务正在生成,点击查看”
  • 会话提醒:“对话超时,点击继续会话”

🔚 小结

Element Plus 的 ElNotification 虽然是用于展示型通知,但通过 h() 渲染函数可以实现非常灵活的交互内容。借助 Vue3 的组合式 API,我们还能轻松实现批量通知管理、动态事件绑定,极大提升了用户体验与可维护性。

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

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

相关文章

下载webrtc M114版本源码只能使用外网googlesource源-命令版

声网、国内源都不行&#xff0c;只能外网googlesource源&#xff01;&#xff01;&#xff01; 二、创建 Ubuntu 容器&#xff08;带目录挂载&#xff09; 拉取Ubuntu镜像 docker pull ubuntu:22.04创建并启动容器&#xff08;挂载Windows目录到容器&#xff09; docker run -i…

Linux运维新手的修炼手扎之第21天

Nginx服务和Tomcat服务1 负载均衡语法格式&#xff1a;upstream[一个或多个]rootubuntu24-13:~# vim /etc/nginx/conf.d/vhost.confupstream group1 {server 10.0.0.16;}upstream group2 {server 10.0.0.14;}server {listen 80;server_name sswang1.magedu.com;location / {pro…

TrOCR: 基于Transformer的光学字符识别方法,使用预训练模型

温馨提示&#xff1a; 本篇文章已同步至"AI专题精讲" TrOCR: 基于Transformer的光学字符识别方法&#xff0c;使用预训练模型 摘要 文本识别是文档数字化中的一个长期研究问题。现有方法通常基于CNN进行图像理解&#xff0c;基于RNN进行字符级文本生成。此外&#…

西门子工业软件全球高级副总裁兼大中华区董事总经理梁乃明先生一行到访庭田科技

概要2025年6月&#xff0c;西门子工业软件全球高级副总裁兼大中华区董事总经理梁乃明先生一行到访我司。庭田科技总经理聂春文携销售团队对西门子代表团表示热烈欢迎&#xff0c;并就当前业务发展方向及未来行业聚焦领域与代表团展开深入交流。 聂春文总经理及销售团队陪同西门…

在 Jenkins 中使用 SSH 部署密钥

本文档介绍了如何在 Jenkins 中配置 SSH 部署密钥&#xff0c;以便更稳定地拉取 Git 仓库代码&#xff0c;避免常见的 RPC 错误。 1. 背景 在使用 Jenkins 进行持续集成时&#xff0c;常常需要从 Git 仓库拉取代码。如果使用 HTTP/HTTPS 协议&#xff0c;有时会遇到 RPC 错误&…

小红书采集工具:无水印图片一键获取,同步采集笔记与评论

我用python语言开发了一款名为“爬xhs图片软件”的工具&#xff0c;该工具不仅能采集图片&#xff0c;还可获取笔记数据、评论数据等内容。 软件界面长这个样子&#xff1a; 采集到的图片&#xff1a;演示视频&#xff1a;https://live.csdn.net/v/485813介绍文章、想你所想&am…

Java行为型模式---命令模式

命令模式基础概念命令模式&#xff08;Command Pattern&#xff09;是一种行为型设计模式&#xff0c;其核心思想是将请求封装为一个对象&#xff0c;从而使你可以用不同的请求对客户进行参数化&#xff0c;对请求排队或记录请求日志&#xff0c;以及支持可撤销的操作。命令模式…

Android性能优化之包体积优化

一、包体积组成与瓶颈分析 1. 典型 APK 结构占比 #mermaid-svg-KEUQMlEifvHlk1CV {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-KEUQMlEifvHlk1CV .error-icon{fill:#552222;}#mermaid-svg-KEUQMlEifvHlk1CV .erro…

开源Web播放器推荐与选型指南

Video.js3&#xff1a;是市面上最流行的免费、开源 HTML5 视频播放器之一。可用于直播和点播&#xff0c;支持 HLS、DASH、WebM 和 MP4 等多种格式。它可高度自定义&#xff0c;开源社区中有很多皮肤可供选用&#xff0c;还可通过插件配置 Multi - DRM、广告插入、字幕等功能&a…

sql注入以及Python二分查找

sql注入 /level1.php?name<script>alert(1)</script> "><script>alert(1)</script> οnclickalert(1) " οnclick"alert(1) "><a href"javascript:alert(1)"> "><a HrEf"javascript:alert…

Coze智能体开发实战-旅游助手

智能体第1步&#xff1a;创建智能体第2步&#xff1a;设置开场白您好&#xff0c;我是广州长隆野生动物园旅游助手&#xff0c;有什么能够帮您&#xff1f;1.景点讲解 2.行程规划 3.天气查询 4.酒店查询第3步&#xff1a;创建工作流第4步&#xff1a;添加“意图识别”行程规划第…

51c视觉~合集13

自己的原文哦~ https://blog.51cto.com/whaosoft/11685452 #GKGNet 多标签分类遇上图卷积网络ViG 本文提出了第一个完全图卷积模型&#xff0c;基于分组K近邻的图卷积网络GKGNet&#xff0c;该模型在灵活且统一的图结构中&#xff0c;同时建模语义标签嵌入与图像块之…

子数组的最大累加和问题(8)0718

题目给定一个数组arr&#xff0c;返回子数组的最大累加和。例如&#xff0c;arr[1,-2,3,5,-2,6,-1],所有的子数组中&#xff0c;[3,5,-2,6]可以累加出最大的和12&#xff0c;所以返回12.解答如果arr中没有正数&#xff0c;产生的最大累加和一定是数组中的最大值。如果arr中有正…

LINUX例行性工作(计划任务)实验操作 ---at和crontab以及系统级别的计划任务

1.atd和crond两个任务管理程序的区别at命令是在指定的时间下只能执行一次任务&#xff1b;crontab命令是可以循环重复&#xff08;周期性&#xff09;的执行定时任务&#xff0c;与windows中的计划任务有些类似.2.指定在2024/08/15 09:00将时间写入testmail.txt文件中[rootmast…

二进制写入与文本写入的本质区别:系统视角下的文件操作

目录 一、核心概念 二、二进制写入 1、特点 2、使用场景 3、二进制写入整数 12345 的详细解析示例 1. 变量声明与初始化 2. 文件打开 3. 二进制写入 4. 文件关闭 二进制表示分析 文件内容 重要注意事项 三、文本写入 1、特点 2、使用场景 3、文本模式写入整数的…

在ComfyUI中CLIP Text Encode (Prompt)和CLIPTextEncodeFlux的区别

CLIP Text Encode (Prompt)CLIPTextEncodeFlux在 ComfyUI 中对 token 支持长度是否相同的详细技术对比&#xff1a;1、 CLIP Text Encode (Prompt)通常来自&#xff1a;ComfyUI 官方自带 CLIPTextEncode 节点。特点&#xff1a; ✅ 使用 OpenAI CLIP 模型&#xff08;ViT-L/14 …

Qt窗口(1)-菜单栏

Qt窗口 概念简述 与QWidget的区别&#xff1a; QWidget更多是作为一个窗口的一部分 基本结构构成&#xff1a;以Xshell举例子比较菜单栏和工具栏&#xff1a; 菜单栏&#xff1a;工具栏&#xff1a;工具栏本质是把菜单栏中一些比较常用的选项&#xff0c;直接放到工具栏中&…

弱网测试

使用软件MAC端&#xff1a;Network Link ConditioneriOS端&#xff1a;设置->开发者->网络链接调节器相关参数带宽单位为Kbps&#xff0c;丢包率单位是百分比&#xff0c;延迟单位是msDownlink Bandwidth &#xff08;输入宽带&#xff09;&#xff1a;设备从服务器接收数…

Nuxt 4.0 深度解析:从架构革新到实战迁移 [特殊字符]

引言&#xff1a;Vue生态的"瑞士军刀"又升级了&#xff01; 如果把前端框架比作超级英雄&#xff0c;Nuxt.js 绝对是Vue阵营里最全能的那位——就像钢铁侠的战甲不断迭代升级&#xff0c;Nuxt也从最初的SSR解决方案&#xff0c;进化成了如今的全栈开发框架。2025年&a…

【Linux内核模块】模块参数详解

玩过智能家居的朋友都知道&#xff0c;一盏智能灯通常有亮度调节、色温切换的功能 —— 这些可调节的选项让设备更灵活。其实 Linux 内核模块也有类似的调节旋钮&#xff0c;今天要聊的模块参数。它能让你在加载模块时动态配置参数&#xff0c;不用改代码就能实现功能切换&…