转载链接:https://blog.csdn.net/csdn_yudong/article/details/101271214

ElementUI 通知组件(notification) 多个时会重叠问题的解决方案
问题场景
问题分析
解决方案
方案一 Promise
方案二 setTimeout
解决后效果
最后 - 示例
问题场景
使用 ElementUI 时,当你在一次触发事件中,调用了两次或更多的 相同位置 的 $notify 时,这时候,弹出的通知框会重叠。
比如:

doNotify() {
this.$notify({
title: '我的通知',
message: '右下角弹出的消息',
position: 'bottom-right'
})
this.$notify({
title: '我的通知',
message: '右上角弹出的消息',
position: 'bottom-right'
})
},
1
2
3
4
5
6
7
8
9
10
11
12
或者

doNotify() {
for(let i=0; i<3; i++) {
this.$notify({
title: '我的通知呀',
message: '右下角弹出的消息',
position: 'bottom-right'
})
}
}
1
2
3
4
5
6
7
8
9
触发这个 doNotify 方法,看到的弹窗是重叠的:

问题分析
每一个通知组件在显示之前需要计算它应该显示的位置,他需要知道它前面的 通知实例 有多少个,然后进一步计算它自己应该显示的位置。(它需要计算前一个通知组件的高度,然后再加上每个通知组件之间的间距 16px)

但是就像 Vue 官网里面 所说的:Vue 在更新 DOM 时是 异步 执行的。只要侦听到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据变更。然后,在下一个的事件循环“tick”中,Vue 刷新队列并执行实际 (已去重的) 工作。

所以,在一个事件中,它不是立马生效的,它会本次事件队列完成后生效。

解决方案
Vue 在内部对异步队列尝试使用原生的 Promise.then、MutationObserver 和 setImmediate,如果执行环境不支持,则会采用 setTimeout(fn, 0) 代替。

You can use promise and setTimeout to solution

方案一 Promise
data() {
return {
notifyPromise: Promise.resolve()
}
},
methods: {
doNotify1() {
for(let i=0; i<3; i++) {
this.notifyPromise = this.notifyPromise.then(() => {
this.$notify({
title: '我的通知',
message: '右下角弹出的消息',
position: 'bottom-right'
})
})
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
方案二 setTimeout
data() {
return {
timer: null
}
},
methods: {
doNotify2() {
for(let i=0; i<3; i++) {
this.timer = window.setTimeout(() => {
this.$notify({
title: '你的弹窗',
message: '右下角弹出的消息',
position: 'bottom-right'
})
}, 0)
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

最新文章

  1. 2D、3D形变
  2. js中获取窗口高度的方法
  3. 《java JDK7 学习笔记》之类和对象
  4. http://blog.sina.com.cn/s/blog_5bd6b4510101585x.html
  5. Cacti的基本使用
  6. [moka学习笔记]yii2设置语言和时区
  7. android中的坐标系以及获取坐标的方法
  8. Android驱动调试利器Busybox之初体验
  9. Sky数[HDU2097]
  10. WPF 增加合计一栏
  11. 树莓派 安装 php
  12. HNOI2010弹飞绵羊
  13. 获取iOS设备信息(内存/电量/容量/型号/IP地址/当前WIFI名称)
  14. ios开发时候,出现A valid provisioning profile for this executable was not found 错误
  15. 【实习记】2014-08-26都是回车惹的祸——shell脚本必须是unix行尾
  16. 如何在内存中压缩并加密ZIP
  17. 模拟美萍加密狗--Rockey2虚拟狗(五)
  18. Node.cluster
  19. 【Linux&amp;amp;Unix--open/close/write/read系统调用】
  20. PWA学习心得

热门文章

  1. Vue组件开发分享
  2. Android studio module生成jar包,module中引用的第三方库没有被引用,导致java.lang.NoClassDefFoundError错误。
  3. Windows 10 下 GCC / LLVM 的安装和使用
  4. 使用代码获得Hybris Commerce里显示的产品图片
  5. postgresql9.5编译安装体验
  6. 【转】STM32生成的文件大小探索
  7. Odoo中的五种Action详解
  8. 为Linux操作系统配置SSH互信
  9. opencv想到的
  10. selenium安装