message.js 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /*
  2. element-ui中的message在实际使用过程中很多时候会遇到,相同的message会在短时间内同时出现在页面上,这种情况下是没有必要的。比如一个错误信息提示被放在定时器中进行:定时调用某个接口,然后这个接口会返回一个message的话,在定时器时间设置很短的情况下,就会出现短时间内弹出很多相同的message。我们可以通过重写element-ui的message来解决这个问题。
  3. */
  4. import { Message } from 'element-ui'
  5. const showMessage = Symbol('showMessage')
  6. /**
  7. * 封装element-ui message方法,只有在页面没有message或者没有相同message的情况下才弹出该message
  8. */
  9. class ElMessage {
  10. success(options, single = true) {
  11. this[showMessage]('success', options, single)
  12. }
  13. warning(options, single = true) {
  14. this[showMessage]('warning', options, single)
  15. }
  16. info(options, single = true) {
  17. this[showMessage]('info', options, single)
  18. }
  19. error(options, single = true) {
  20. this[showMessage]('error', options, single)
  21. }
  22. /* eslint-disable */
  23. [showMessage](type, options, single) {
  24. if (single) {
  25. let canShow = true;//设置值控制显示当前message
  26. let messageArr = document.getElementsByClassName('el-message');//获取页面所有已经存在的message
  27. //遍历获取到的message DOM集合,如果页面已存在的message中有显示文本和当前message相同的情况,canShow设置为false
  28. for (let i = 0; i < messageArr.length; i++) {
  29. if (options == messageArr[i].getElementsByClassName('el-message__content')[0].innerHTML) {
  30. canShow = false;
  31. }
  32. }
  33. //如果页面不存在message或者canShow==true,则正常执行该message
  34. if (messageArr.length == 0 || canShow) {
  35. Message[type](options)
  36. }
  37. } else {
  38. Message[type](options)
  39. }
  40. }
  41. }
  42. export {
  43. ElMessage
  44. }