RecyclerView踩坑记(持续更新中……)

1、


Paste_Image.png

今晚把自己项目中的ListView换成了RecyclerView,结果就踩坑了
item_layout进行了如下修改


Paste_Image.png
    @Override
    public RecordRecyclerViewViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = mInflater.inflate(R.layout.item_layout, null);//<-------------------------------------------
        RecordRecyclerViewViewHolder holder = new RecordRecyclerViewViewHolder(view);
        return holder;
    }

以前ListView都是这样写的,所以item_layout中的TextView外面再包裹一层FrameLayout,是为了宽度填充满,然而RecyclerView中要是再这么写,外面的FrameLayout也不帮忙了,结果如下
ListView中使用inflate(R.layout.item_layout, null),ListView不会为其中的item提供布局参数,这时item_layout外面如果加一个FrameLayout还能起到想要的效果,如果不加,即使TextView 的宽度是wrap_content,显示的效果也是match_parent,但是最好也用inflate(R.layout.item_layout, parent,false),这样就不用再加FrameLayout,减少布局的嵌套。

Paste_Image.png

正确写法如下:

    @Override
    public RecordRecyclerViewViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = mInflater.inflate(R.layout.item_layout, parent,false);//<-------------------------------------------
        RecordRecyclerViewViewHolder holder = new RecordRecyclerViewViewHolder(view);
        return holder;
    }
Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容