美文网首页自定义view
文章详情页的实现——WebView和RecyclerView混合

文章详情页的实现——WebView和RecyclerView混合

作者: Sibyl预 | 来源:发表于2017-02-23 16:08 被阅读973次

    近日接到一个需求,需要在一个页面上方用webview显示网页的内容,下半部分用原生实现一个评论列表。

    网页承载部分 网页和原生列表交界处

    初步想法有两个:

    1、Header模式:用RecyclerView显示原生的评论列表,把WebView作为RecyclerView的第0项。

    ViewGroup.LayoutParams lp =newViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.WRAP_CONTENT);

    WebView web =newWebView(parent.getContext());

    web.setLayoutParams(lp);

    需要把WebView撑开,保证WebView的内容完全展示。

    2、ScrollView模式:最外层用NestedScrollView容器,内层放一个LinearLayout,从上到下依次是WebView和RecyclerView;

    布局树

    布局上没有什么大的问题,就是滚动会觉得有点卡,没有关系,设置一下就好了。

    LinearLayoutManager layoutManager =newLinearLayoutManager(this);

    layoutManager.setSmoothScrollbarEnabled(true);

    layoutManager.setAutoMeasureEnabled(true);

    recyclerView.setLayoutManager(layoutManager);

    recyclerView.setHasFixedSize(true);

    recyclerView.setNestedScrollingEnabled(false);

    recyclerView.setLayoutManager(layoutManager);

    Pros and Cons:

    总的来说,优缺点非常明显,在评论列表条数特别多(实验时用了500条)的时候:

    页面初始化结束时:Header模式申请的内存为25.77m;ScrollView模式申请的内存为37.87m

    列表滚动到底时:Header模式申请的内存为28.09m; ScrollView模式申请的内存为40.63m

    gc后:Header模式申请的内存为25.05m; ScrollView模式申请的内存为27.77m

    Example: https://github.com/bobbySpace/WebviewAndList


    相关文章

      网友评论

        本文标题:文章详情页的实现——WebView和RecyclerView混合

        本文链接:https://www.haomeiwen.com/subject/nbrbwttx.html