1.前言
我们知道Element中新的弹出框的展示,总是覆盖着上一个弹出框。实现覆盖功能需要保证新的弹出框的z-index要比旧的弹出框的z-index值相等或着更高,
为达到这个目的element为所有的弹出框(所有下拉框、提示框、Dialog对话框等等)直接或间接的使用到一个js组件element-ui/src/utils/vue-popper
,
而这个vue-popper又使用了另一个组件element-ui/src/utils/popup/popup-manager.js
。
PopupManager
PopupManager中有一个zIndex属性初始值为2000,所有的弹出框的z-index其实都是从这个PopupManager.zIndex中获取的,当要展示一个新的弹出框时,
组件便会通过 PopupManager.nextZIndex() 获取最新的PopupManager.zIndex,nextZIndex返回PopupManager.zIndex++,这样就保证了新的弹出框总是比旧的弹出框z-index大,
省去自己一个个设置的麻烦,也减少问题的出现。
2.遇到的问题
使用原生element组件弹窗没什么问题,但是因为项目中需要改动日期组件的,所以复制了一份element日期组件源码做改动。
按照项目要求的逻辑改完,在项目中运行一切正常,但是后面有客户提出弹窗中日期选择面板被覆盖的问题,需要点击很多次才会正常展示,通过调试发现日期组件的z-index 和其他弹窗的z-index 是分开计数的,所以其他弹窗的z-index大于日期组件的z-index,就会出现被覆盖的问题,这只能说明日期和其他组件获取z-index的不是同一个PopupManager
查看了先data-picker下的picker.vue其中引用vue-popper
import Popper from 'element-ui/lib/utils/vue-popper';
没毛病,但是其实毛病就出在这引用路径上的src,src就是source源的意思,源码中互相引用没问题,但是我们在项目中使用element组件的使用,并不是来自源码,而是来自源码编译出来的依赖库,是npm模块中lib目录下的文件。所以我们的自定义组件用了一个新的PopupManager对象跟原生element组件不同的PopupManager,导致zIndex不同步,展示错误。
3.解决
修改picker.vue,将原先import Popper from 'element-ui/src/utils/vue-popper'
修改为import Popper from 'element-ui/lib/utils/vue-popper'