element-ui弹出多个message的问题处理
Posted 骑着代马去流浪
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了element-ui弹出多个message的问题处理相关的知识,希望对你有一定的参考价值。
重写element-ui的message
方法一:弹出之前判断是否有多个,有则不弹出,没有则弹出一个
resetMessage.js:
/**重置message,防止重复点击重复弹出message弹框 */
import
Message
from 'element-ui';
const showMessage = Symbol('showMessage')
class DoneMessage
[showMessage](type, options, single)
if (single)
if (document.getElementsByClassName('el-message').length === 0)
Message[type](options)
else
Message[type](options)
info(options, single = true)
this[showMessage]('info', options, single)
warning(options, single = true)
this[showMessage]('warning', options, single)
error(options, single = true)
this[showMessage]('error', options, single)
success(options, single = true)
this[showMessage]('success', options, single)
export const message = new DoneMessage();
main.js调用:
import
message
from '@/utils/resetMessage';
、、、、
Vue.use(ElementUI)
Vue.prototype.$message = message;
方法二:弹出前判断是否有相同弹出框,若有则关闭它再弹出新的
resetMessage.js:
/**重置message,防止重复点击重复弹出message弹框 */
import
Message
from 'element-ui';
let messageInstance = null;
const resetMessage = (options) =>
if(messageInstance)
messageInstance.close()
messageInstance = Message(options)
;
['error','success','info','warning'].forEach(type =>
resetMessage[type] = options =>
if(typeof options === 'string')
options =
message:options
options.type = type
return resetMessage(options)
)
export const message = resetMessage
调用方法跟方法一一致
以上是关于element-ui弹出多个message的问题处理的主要内容,如果未能解决你的问题,请参考以下文章
Vue 项目中使用ElementUI 框架中message 对话框实例对象
vue 使用element-ui中的Notification自定义按钮并实现关闭功能以及如何处理多个通知