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)

相关推荐
IT_陈寒34 分钟前
React性能优化踩的坑,这个错你可能也会犯
前端·人工智能·后端
zhangxingchao1 小时前
AI应用开发三:RAG技术与应用
前端·人工智能·后端
摘星小杨1 小时前
如何在前端循环调取接口,实时查询数据
开发语言·前端·javascript
Hilaku1 小时前
从搜索排名到 AI 回答? 先聊一聊 AI 可见度工具 BuildSOM !
前端·javascript·程序员
zzmgc41 小时前
纯静态 + Web Worker + 虚拟滚动:我是怎么让浏览器吃下 10MB JSON 不卡的
前端·架构
辰同学ovo1 小时前
用 Chrome DevTools MCP 给 AI 写的页面做“质检“
前端·人工智能·chrome devtools
乌托邦1 小时前
uni-mini-ci:让 uniapp 小程序构建后自动预览和上传
前端·vue.js·uni-app
豹哥学前端2 小时前
前端工程化实战:从包管理到 Vite 配置,一套下来全明白
前端·javascript·vite
网安小白2 小时前
如果解决github域名解析问题
前端
葬送的代码人生2 小时前
用一句 Prompt 十分钟搓出完整应用
前端·html·ai编程