在recyclerview中使用其item布局的ViewBinding类需要注意的问题

问题描述

最近在使用RecycerView的瀑布流布局,我想直接用ViewBinding取得item中的一个TextView然后根据position进行赋值。

比如我点击测试标题2,它在日志中应该能打印出测试标题2才对。

在这里插入图片描述

但是他却打印出“测试标题0”

在这里插入图片描述

按理来说标题应该更点击的位置对的上才对。
但是发现瀑布流的布局根本不是按照数据集里的顺序进行排列的,而是出现了数据错乱重复、点击的位置跟标题对不上的情况。

问题原因

我们每个item不是有一个布局吗?我使用了ViewBinding,他会生成一个binding类。
我在RecyclerView的适配器中没有使用ViewHolderitem布局里的控件进行操作,而是直接通过生成的Binding类进行操作:

@Override
    public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {

        if(getItemViewType(position) == DefaultVals.POST_TYPE_TEXT){
            mItemTypeTextBinding.userAvatar2.setImageResource(R.drawable.ic_launcher_background);
            mItemTypeTextBinding.userUnit2.setText(mPostItems.get(position).getUserHouseAddr());
            mItemTypeTextBinding.postTitle2.setText(mPostItems.get(position).getPostTitle());
            mItemTypeTextBinding.postContent2.setText(mPostItems.get(position).getPostContent());
            mItemTypeTextBinding.postTag2.setText(mPostItems.get(position).getPostTag());
            mItemTypeTextBinding.postDate2.setText(mPostItems.get(position).getPostDate());
        }

这样会出现有些item是重复的。因为Binding类实例在适配器中只有一个,当我们进行滑动的时候,就会调用onBindViewHolder,而一次onBindViewHolder的调用postion是确定的,里面直接根据position通过binding类来设定布局,这样就会产生很多个相同的item。所以就会出现item重复,继而引发数据错乱,标题对不上位置。

解决

不要在onBindViewHolder中直接通过生成的Binding类来操作控件,老老实实用viewHolderViewBinding类本质是解决满屏都是findViewById的问题,只是让你减少了使用大量重复findViewById的工作量,使用它来操作控件要谨慎再谨慎。

建立自己的viewHolder,通过它对item的控件进行操作。

    class ViewHolderWithContent extends RecyclerView.ViewHolder{
        public ImageView userAvatar ;
        public TextView username ;
        public TextView userUnit ;
        public TextView postTitle ;
        public TextView postContent ;
        public TextView postTag ;
        public TextView postDate ;
        public ViewHolderWithContent(@NonNull View itemView) {
            super(itemView);

            userAvatar = itemView.findViewById(R.id.user_avatar2);
            username = itemView.findViewById(R.id.username2);
            userUnit = itemView.findViewById(R.id.user_unit2);
            postContent= itemView.findViewById(R.id.post_content2);
            postTitle = itemView.findViewById(R.id.post_title2);
            postTag = itemView.findViewById(R.id.post_tag2);
            postDate = itemView.findViewById(R.id.post_date2);
        }
    }

onBindViewHolder中通过自己的ViewHolder进行控件操作:

@Override
    public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {

        if(getItemViewType(position) == DefaultVals.POST_TYPE_TEXT){

            ((ViewHolderWithContent)holder).userAvatar.setImageResource(R.drawable.ic_launcher_background);
            ((ViewHolderWithContent)holder).username.setText(mPostItems.get(position).getUsername());
            ((ViewHolderWithContent)holder).userUnit.setText(mPostItems.get(position).getUserHouseAddr());
            ((ViewHolderWithContent)holder).postTitle.setText(mPostItems.get(position).getPostTitle());
            ((ViewHolderWithContent)holder).postContent.setText(mPostItems.get(position).getPostContent());
            ((ViewHolderWithContent)holder).postTag.setText(mPostItems.get(position).getPostTag());
            ((ViewHolderWithContent)holder).postDate.setText(mPostItems.get(position).getPostDate());

//            mItemTypeTextBinding.userAvatar2.setImageResource(R.drawable.ic_launcher_background);
//            mItemTypeTextBinding.userUnit2.setText(mPostItems.get(position).getUserHouseAddr());
//            mItemTypeTextBinding.postTitle2.setText(mPostItems.get(position).getPostTitle());
//            mItemTypeTextBinding.postContent2.setText(mPostItems.get(position).getPostContent());
//            mItemTypeTextBinding.postTag2.setText(mPostItems.get(position).getPostTag());
//            mItemTypeTextBinding.postDate2.setText(mPostItems.get(position).getPostDate());
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值