Liweifeng
Liweifeng
要快太多了
不过需要授权,有点麻烦
补充一下,如果是这种状态基本判定无法大规模使用,只能做局部模块缓存使用。 以 https://github.com/IVLIU/react-offscreen/issues/5 这个 issue 大概率是一个问题。
> > 补充一下,如果是这种状态基本判定无法大规模使用,只能做局部模块缓存使用。 以 #5 这个 issue 大概率是一个问题。 > > 是同一个问题,但这个问题不是Activity可以解决调的 React原生的 Activity 没有这个问题, 可以查看具体原因,如果是 html 未隐藏才导致有这个动画,那也有办法处理。 还有一点这种处理方式跟原生有很大差异的一点就是 useEffect 不会执行,这个可以通过修改React useEffect是否可以实现。
> 还有一点这种处理方式跟原生有很大差异的一点就是 useEffect 不会执行,这个可以通过修改React useEffect是否可以实现 没解决,暂时不用了。还用老方法了,不过老方法性能低。
> > 补充一下,如果是这种状态基本判定无法大规模使用,只能做局部模块缓存使用。 以 #5 这个 issue 大概率是一个问题。 > > 5 4 如果默认motionLeave为true的话,会默认走一遍动画流程,看下是否可以关闭 我昨天也看了源码,大概率不能这么搞,大概率是生命周期的问题: 那么如果不用Activity,直接用DIsplay: none 的方式会不会也有这个问题呢?显然,没有这个问题。 导致这个问题的主要原因还是生命周期,没有执行 effect 回调,以及没有执行Effect 返回函数。 **这里强调一点:原生的 Activity 再每次显示隐藏会执行副作用。** 佐证:事件监听再 组件卸载的时候会移除。https://github.com/react-component/motion/blob/f18d5f419952578b675c092bacac0eb376a986c5/src/hooks/useDomMotionEvents.ts#L45-L50  还有其他很多地方有副作用相关内容,单纯的把离开动画关闭,可能会导致意想不到的结果。
> > > > 补充一下,如果是这种状态基本判定无法大规模使用,只能做局部模块缓存使用。 以 #5 这个 issue 大概率是一个问题。 > > > > > > > > > 5 4 如果默认motionLeave为true的话,会默认走一遍动画流程,看下是否可以关闭 > > > > > > 我昨天也看了源码,大概率不能这么搞,大概率是生命周期的问题: >...