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的问题处理的主要内容,如果未能解决你的问题,请参考以下文章

element-ui 页面刷新自动弹Message问题

前端常遇到的问题!!!

Vue 项目中使用ElementUI 框架中message 对话框实例对象

vue 使用element-ui中的Notification自定义按钮并实现关闭功能以及如何处理多个通知

vue使用elementUI,接口报错message消息提示弹出过多问题

element-ui MessageBox 弹框,我只想要弹出样式,不想要点击,当做一个弹出提醒,两秒后自动关闭