浅谈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-12-03 15:50:00

    html5 audio stop功能

    html5并没有提供停止功能,我们需要通过其他方式来实现这个问题,下面我们来看下神仙般的操作。

  • 2019-12-03 16:33:49

    hapi,nuxtjs跨域请求

    简单请求 与 预检请求,Fetch 与 CORS 的一个有趣的特性是,可以基于 HTTP cookies 和 HTTP 认证信息发送身份凭证。一般而言,对于跨域 XMLHttpRequest 或 Fetch 请求,浏览器不会发送身份凭证信息。如果要发送凭证信息,需要设置 XMLHttpRequest 的某个特殊标志位。

  • 2019-12-03 16:36:03

    跨域资源共享 CORS 详解

    阮一峰大哥的文章写的不错,推荐,也推荐他的整个王章,大家可以去看一下啊。

  • 2019-12-03 16:37:01

    去除options,减少options的访问

    因为跨域请求,浏览器可能(后面讲)会发送一次options请求,如果处理不好,跨域还是会gg的。 之前很少涉及跨域,涉及也是简单请求(下面阮老师文章中区别热简单请求和复杂请求),所以基本不会很少关注options。后面就遇到坑了,下面讲讲注意点。