JetPack之DataBinding的使用

前言

这篇文章主要讲解JetPack中的DataBinding组件的使用。

简单实用

解决问题:当界面被改写的时候,Activity中的控件代码也必须被改写。为了避免这个问题的发生,使用了databinding。

  • Build.gradle配置项目使用dataBinding功能
defaultConfig{
   
  ...
  dataBinding{
   
     enabled true
  }
  ...
}
  • 将布局文件转换成dataBinding适配的布局文件
  • 反向绑定(数据回绑到界面上)
    • 在xml中的标签声明变化的数据。
    • 通过@{}绑定变量和函数@{()->函数名称}
<layout>

  <data>
<!-- 声明变量 
name:变量名称
type:变量类型-->
     <variable
         name="jetViewModel"
         type="com.martin.jetmo.jetpack.JetViewModel" />
    
 <!-- 导包-->   
      <import type="com.dustess.baselib.common.assist.Check" />
  
  </data>
	
   <!-- 
使用时需要将文件语法
   字符串:@{字符串内容},在引用时变量时,必须要有getXXX的函数,否则编译报错。
   调用函数:@{()->调用的函数}
   -->  
  <TextView
            android:id="@+id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{String.valueOf(jetViewModel.likeNumber)}"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_bias="0.196" />
  
  <Button
            android:id="@+id/button"
            android:layout_width="87dp"
            android:layout_height="36dp"
            android:text="+1"
            android:onClick="@{()->jetViewModel.add()}"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/textView" />
  
<layout>
  • 正向绑定
    • setCo
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值