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)

相关推荐
curdcv_po4 分钟前
我接入了微信小说小程序官方阅读器
前端·微信小程序
程序员鱼皮12 分钟前
什么是 RESTful API?凭什么能流行 20 多年?
前端·后端·程序员
+VX:Fegn089512 分钟前
计算机毕业设计|基于springboot + vue健身房管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
www_stdio21 分钟前
让大语言模型拥有“记忆”:多轮对话与 LangChain 实践指南
前端·langchain·llm
inferno21 分钟前
JavaScript 基础
开发语言·前端·javascript
cindershade27 分钟前
Intersection Observer 的实战方案
前端
青莲84329 分钟前
Kotlin Flow 深度探索与实践指南——中部:实战与应用篇
android·前端
cindershade30 分钟前
事件委托(Event Delegation)的原理
前端
开发者小天31 分钟前
React中useMemo的使用
前端·javascript·react.js
1024肥宅33 分钟前
JS复杂去重一定要先排序吗?深度解析与性能对比
前端·javascript·面试