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)