前言
我在写H5-dooring时,发现我们用的popover会发生闪跳,而且第一次闪跳就算了,每次还会有另一个方向的闪跳。
于是我大概百度了下,基本都说需要给固定宽高即可,让后试了下发现没用,就算触发组件和弹窗元素都给了宽高,也一样闪跳。由于antd的popover底层的实现是套其他第三方的库,第三方库又用到了其他的前端组件, 所以锁心自己实现一个。
正文
初步实现
首先,我对popover粗略进行实现,主要就是一个弹窗定位问题,然后我照我预想实现后发现,一样会出现闪跳,但只有第一次会闪跳,后面比较正常:
可以看见,第一次显示会在左边,后续显示位置都ok。 所以思路就是让其在第一次显示时进行处理,顺便实现动画效果,不至于出现那么突兀。 由于我想做一个除react外零依赖的,所以就不考虑react-transition-gro