防止element ui message重复弹框

场景

在开发中,请求接口时会遇到没有权限或者其他需要有提示的地方,这个时候就要用到message消息提醒
但是如果同一个页面有多个接口请求的话,就会弹出很多提醒

error.png

解决

利用element-ui中message的close方法,在下一个弹框弹出前先把上一个弹框实例关闭掉


关闭.png

resetMessage.js

import { Message } from 'element-ui'; // 引入message

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

在main.js中引用

import ElementUI from 'element-ui';
import { message  } from './config/resetMessage';
Vue.use(ElementUI)
Vue.prototype.$message = message;

在vue中使用

this.$message({
      type: 'error',
      message: '内容'
  });

在js中使用

import { message  } from './config/resetMessage';
message({
  type: 'error',
  message: '内容'
})
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容