无法使用数据绑定绑定 viewpager2 数据

Posted

技术标签:

【中文标题】无法使用数据绑定绑定 viewpager2 数据【英文标题】:viewpager2 data cannot be bound using databinding 【发布时间】:2021-12-30 17:19:49 【问题描述】:

我在使用数据绑定和 viewpager2 时遇到了问题。我在片段中使用了 viewpager2。 viewpager2 中的 FragmentA 想要共享 Fragment 的视图模型。

    fragmentA中绑定了一个EditText属性文本,但是在viewmodel中无法获取EditText的值。 但是fragmentA绑定了一个点击事件,可以在viewmodel中触发

不知道哪里做错了,第一点就无效了

片段A:

class SignUpMainFragment(val vm:SignUpFragmentVM):Fragment() 
    private var mBinding:FragmentSignUpMainBinding?=null

    override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View 
        mBinding = DataBindingUtil.inflate(inflater, R.layout.fragment_sign_up_main,container,true)
        mBinding?.signUp = vm
        return mBinding?.root!!
    

fragmentA的布局:

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <data>
        <variable
            name="signUp"
            type="com.xxx.SignUpFragmentVM" />
    </data>

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_
        android:layout_>

        <EditText
            android:id="@+id/et_email"
            android:layout_
            android:layout_
            android:layout_marginStart="40dp"
            android:hint="Email"
            android:text="@signUp.txtEmail"
            android:textSize="30sp"
            android:textColor="@color/color_aaa280"
            android:drawableStart="@mipmap/img_mail"
            android:paddingStart="26dp"
            android:drawablePadding="18dp"
            android:inputType="textEmailAddress"
            android:background="@drawable/shape_edit_bg_e7e7e7"
            app:layout_constraintTop_toTopOf="@id/et_name"
            app:layout_constraintStart_toEndOf="@id/et_name" />

        <TextView
            android:id="@+id/tv_send_code"
            android:layout_
            android:layout_
            android:text="@signUp.txtSendEmail"
            android:textSize="30.5sp"
            android:textColor="@color/color_71cbc0"
            android:onClick="@signUp.click"
            android:clickable="true"
            android:layout_marginStart="25dp"
            app:layout_constraintTop_toTopOf="@id/et_lock_psw"
            app:layout_constraintBottom_toBottomOf="@id/et_lock_psw"
            app:layout_constraintStart_toEndOf="@id/et_lock_psw"/>
    </androidx.constraintlayout.widget.ConstraintLayout>
</layout>

【问题讨论】:

【参考方案1】:

如果您的目标是当用户在 editTextView 中输入一些文本时在 viewModel 中获取数据,那么您应该使用两种方式的数据绑定。

示例如下:

<EditText
            android:id="@+id/et_email"
            android:layout_
            android:layout_
            android:layout_marginStart="40dp"
            android:hint="Email"
            android:text="@=signUp.txtEmail" //<---- two way dataBinding
            android:textSize="30sp"
            android:textColor="@color/color_aaa280"
            android:drawableStart="@mipmap/img_mail"
            android:paddingStart="26dp"
            android:drawablePadding="18dp"
            android:inputType="textEmailAddress"
            android:background="@drawable/shape_edit_bg_e7e7e7"
            app:layout_constraintTop_toTopOf="@id/et_name"
            app:layout_constraintStart_toEndOf="@id/et_name" />

@= 表示法,重要的是包括“=”符号,接收属性的数据更改并同时监听用户更新。

更多two way dataBinding

【讨论】:

哇,这太棒了,非常感谢,这解决了我的问题。但是当我不使用viewpager2(在正常布局中)时,我没有使用双向绑定。 Viewmodel 可以得到edittext的文本,这让我觉得很疑惑。 接下来又遇到了一个问题。 FragmentA中的另一个控件是发送验证码的按钮(TextView)。当我按下它时,它需要有一个60秒的倒计时,所以我使用postValue来改变TextView的@signUp.txtSendEmail。但是不行,你知道问题所在吗?

以上是关于无法使用数据绑定绑定 viewpager2 数据的主要内容,如果未能解决你的问题,请参考以下文章

Android MVVM框架搭建RecyclerVIew + ViewPager2 + BaseQuickAdapter

使用 uibmodal 控制器绑定模板视图

无法使用数据绑定设置过滤器值?

Yii2 select2 数据库异常绑定变量数与令牌数不匹配

无法将绑定控制更改推送到数据集

尝试从实时数据库绑定数据以获取列表视图