无法使用数据绑定绑定 viewpager2 数据
viewpager2 data cannot be bound using databinding
我在使用数据绑定和viewpager2 时遇到问题。我在片段中使用了 viewpager2。 viewpager2 中的 FragmentA 想要共享片段的视图模型。
- 在fragmentA中绑定了一个EditText属性text,但是在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_width="match_parent"
android:layout_height="match_parent">
<EditText
android:id="@+id/et_email"
android:layout_width="468dp"
android:layout_height="94dp"
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_width="wrap_content"
android:layout_height="wrap_content"
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>
如果您的目标是当用户在您的 editTextView
中输入一些文本时在 viewModel 中获取数据,那么您应该使用双向数据绑定。
示例如下:
<EditText
android:id="@+id/et_email"
android:layout_width="468dp"
android:layout_height="94dp"
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 时遇到问题。我在片段中使用了 viewpager2。 viewpager2 中的 FragmentA 想要共享片段的视图模型。
- 在fragmentA中绑定了一个EditText属性text,但是在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_width="match_parent"
android:layout_height="match_parent">
<EditText
android:id="@+id/et_email"
android:layout_width="468dp"
android:layout_height="94dp"
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_width="wrap_content"
android:layout_height="wrap_content"
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>
如果您的目标是当用户在您的 editTextView
中输入一些文本时在 viewModel 中获取数据,那么您应该使用双向数据绑定。
示例如下:
<EditText
android:id="@+id/et_email"
android:layout_width="468dp"
android:layout_height="94dp"
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