我正在使用react naviagation在不同屏幕之间进行导航,尤其是堆栈导航器。我在某些导航过渡上花费的时间太长了。此延迟可能长达4-5秒。延迟的大小与我传递给navigate
函数的数据的权重成正比。我尝试使用InteractionManager.runAfterInteractions
函数来加速脱机加载,但这并没有帮助,因为脱机加载本身似乎需要处理传递的数据,并且只有在过渡之后才进行处理。
我一开始就在应用程序中提取所有数据。因此,当我导航到另一个屏幕时,没有进一步的数据获取。目前,我能想到的唯一解决方法是使用AsyncStorage而不是在导航过程中传递它。有人遇到这个问题吗?如果是这样,您曾经设法解决吗?
我最终将所有内容都加载到redux,然后从中读取,而不是通过导航包传递数据。作为另一种选择,我也可以使用AsyncStorage,但这会被滥用,因为AsyncStorage的操作是异步的,这意味着我需要await
才能获取所需的数据。毕竟,这不是AsyncStorage设计的目的。另一方面,Redux动作是同步的,这使得在这种特殊情况下的生活变得轻松,其主要目的是满足这样的需求。