浅谈Recycleview嵌套卡顿 以及你所不知道的解决方案

2019-05-21 12:34:38

参考地址 浅谈Recycleview嵌套卡顿 以及你所不知道的解决方案

由于项目需要,需要做到recycleview 这里先不讲如何用其他控件代替这种嵌套的方式


先假定你已经嵌套了 老板还不给时间给你给布局方式 那么这个时候你的这个嵌套列表 必定是卡顿的


只要超过一屏,展示效果会有卡顿现象,原因就是由于两个RecyclerView的存在,使得滑动的view滑出当前屏幕的释放存在冲突


每次都执行inflate方法


下面总结网上的几个神方法


1.最常见 的  recyclerView.setNestedScrollingEnabled(false);  这个方法有可能有效 是可以加的


2.重写recycleview


 

public class MyRecycleView extends RecyclerView {

 

    public MyRecycleView(Context context) {

        super(context);

    }

 

    public MyRecycleView(Context context, @Nullable AttributeSet attrs) {

        super(context, attrs);

    }

 

    public MyRecycleView(Context context, @Nullable AttributeSet attrs, int defStyle) {

        super(context, attrs, defStyle);

    }

 

    @Override

    public boolean onInterceptTouchEvent(MotionEvent e) {

        //返回false,则把事件交给子控件的onInterceptTouchEvent()处理

        return false;

    }

 

    @Override

    public boolean onTouchEvent(MotionEvent e) {

        //返回true,则后续事件可以继续传递给该View的onTouchEvent()处理

        return true;

    }

}

这个方法确实有效 但是有坑 比如你的外层recycleview无法滑动等等


3.这个方法是博主 “泡在网上的日子”写的 关于viewpool的使用解决滑动卡顿 的问题,但是我没有尝试 ,所以也不知道怎么样 ,希望有试过的朋友可以留言指教一二  博客地址 :http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2017/0914/8514.html


4.最后的最后 给一些 神功秘籍 这些简单粗暴的方法 是可以帮你解决卡顿问题的


a.调用 预加载方法 setInitialPrefetchItemCount(int) 来优化嵌套时预加载性能,例如横向RecycleView上有3.5个item需要显示,可以调用LinearLayoutManager.setInitialPrefetchItemCount(4),默认的数值是2。


b.设置recycleview的子项缓存 


rv.setItemViewCacheSize(200);


c.继续结合


rv.setHasFixedSize(true);        rv.setNestedScrollingEnabled(false);

完美解决嵌套卡顿


总结:虽然解决了卡顿 但是这种做法目前是不支持的 谷歌本身就不推荐recycleview 嵌套 类似这个需求 我们应该尽可能找类似 ExpandableListView 这些第三方控件来解决



  • 2019-10-16 21:02:47

    vue中mixins的详细分析一

    混入 (mixins): 是一种分发 Vue 组件中可复用功能的非常灵活的方式。混入对象可以包含任意组件选项。当组件使用混入对象时,所有混入对象的选项将被混入该组件本身的选项。

  • 2019-10-16 21:04:47

    vue中mixins的详细分析二

    当混合里面包含异步请求函数,而我们又需要在组件中使用异步请求函数的返回值时,我们会取不到此返回值,如下: