vue3中ElMessage如何动态更改提示消息

1.需求

要求ElMessage的提示消息做成倒计时的效果

2.效果

3.实现代码

javascript 复制代码
function shower(){
    const message = ElMessage({
            type: 'warning', // 提示类型
            dangerouslyUseHTMLString: true, // 使用 HTML 片段作为正文内容
            message: `<div id="kanno"><span>不敢吃太饱.zip-还剩余6分钟</span></div>`, // 提示内容
            duration: 0 // 取消自动关闭提示
        })
}
function kanno(){
    const kannoElement = document.getElementById('kanno');

    // 移除 span 标签
    kannoElement.querySelector('span').remove();

    // 重新插入一个新的 span 标签
    kannoElement.insertAdjacentHTML('beforeend', `<div id="kanno"><span>不敢吃太饱.zip-还剩余2分钟</span></div>`)
}

4.说明

我这里这个两个方法是通过按钮点击事件触发,如需实现倒计时就通过定时器和监听或者计算属性来触发,这里只提供实现的思路。

整个过程的难点在于无法将数据重新渲染到节点上。

shower方法是用来触发消息提示,而kanno方法是用来改变提示内容的方法,可以将该方法中的处理步骤按照需求放在定时器、计算属性、监听等中

整个思路简单来说就是先获取节点,删除节点(删除原来的span),再重新插入节点(插入新的span)

相关推荐
sudo_jin几秒前
从“谁调用指向谁”到“手写Bind源码”,彻底搞懂JavaScript的this机制
前端·javascript
小蜜蜂dry1 分钟前
nestjs实战-登录、鉴权(二)
前端·后端·nestjs
全栈王校长1 分钟前
Nest 文件上传 - 就是增强版的 el-upload
前端·后端·nestjs
ZC跨境爬虫1 分钟前
海南大学交友平台开发实战 day10(后端向前端输出_前端读取数据全流程联调+日志调试落地)
前端·python·sqlite·html·状态模式
xiaotao1312 分钟前
CSS中的Grid 布局
前端·css
cc_heart2 分钟前
antdv-next/x:面向 Vue 的 AI 组件体系
前端·javascript·vue.js
Ruihong3 分钟前
一文看懂:Vue3 watch 用 VuReact 转成 React 长啥样
vue.js·react.js
竹林8183 分钟前
RainbowKit快速集成多链钱包连接:从“一键连接”到“多链切换”的实战踩坑
前端·javascript
用户81274828151204 分钟前
android使用uinput节点任意注入鼠标事件-重学安卓input子系统
前端
用户69371750013845 分钟前
AI来了,同事们的效率为什么差这么多?
android·前端·ai编程