解决 React-Native 加载数据页面卡顿问题

一般情况下,我们在componentDidMount方法里面执行请求数据.根据字面意思:页面组件加载完毕,然后请求数据. 对的 ,没毛病!!!

然而问题就出现,当我们跳转到新页面时,到界面请求完数据,更新状态机.中间会出现一个界面卡顿的现象.我的理解是,页面组件还未加载完就已经开始请求数据了,这应该是RN的一个bug吧,纯属我瞎猜!

解决办法
await InteractionManager.runAfterInteractions();

在componentDidMount()方法中加上InteractionManager.runAfterInteractions();

InteractionManager:从名称上可以看出,这是一个管理互动操作的工具。其中有一个方法runAfterInteraction(func)。这个方法用来标记参数中传入的方法在所有当前进行的交互和动画完成后再执行。可以理解为将func加入到一个等待队列。
我们可以使用这个方法来避免在Component进入画面的动画完成前打断动画的问题。类似于这样:

    async componentDidMount(){
        //当前进行的交互和动画完成后再执行,执行下面的其他方法
        await InteractionManager.runAfterInteractions();
        await this.freshData();
        this.setState({
            ready: true,
        });

    }

请求数据freshData

   freshData= async ()=>{
        //下拉刷新时,重置为1
        this.start=1;
        const json = await this.fetchData();
        this.setState({
            movies: json.data.data.products,
        });
    }

参考:http://blog.csdn.net/angelseedex/article/details/53339107

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 177,091评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,795评论 4 61
  • 1. 老板心态,从来没有设身处地想象自己成为老板是什么样子,总是被动指挥自己,没有想到让自己从更好角度了解假如自己...
    qqjlyou阅读 1,355评论 0 1
  • 犹记得那天晚上一直捧着手机不断地刷新,期待自己喜爱的一位演员在颁奖礼上获得演技大奖。这位演员兼美貌与演技并重,早已...
    Jane_gz阅读 2,823评论 0 0
  • 掀开你的红盖头 惊现一摊黑色漩涡 怎知劲头愈加强烈 一步一步靠近 恋上她的味道 闭眼回味无穷 脑里尽现缠绕画面 有...
    courage9869阅读 1,787评论 0 0

友情链接更多精彩内容