DataBinding onClick 的几种点击方式

有一个 ViewModel 类,有一个 xml,xml 绑定了 ViewModel .

1. @{click}

//xml:
<Button
     android:layout_width="match_parent"
     android:layout_height="48dp"
     android:onClick="@{click}"
/>

//ViewModel:
public void click(View view){

}

2. 不带参数:@{() -> viewModel.click()}

//xml:
<Button
     android:layout_width="match_parent"
     android:layout_height="48dp"
     android:onClick="@{() -> viewModel.click()}"
/>

//ViewModel:
public void click(){

}

3. @{viewModel::click}

//xml:
<Button
     android:layout_width="match_parent"
     android:layout_height="48dp"
     android:onClick="@{viewModel::click}"
/>

//ViewModel:
public void click(View view){

}

tip: 如果是在其它类中设置点击方法,如 EventHandlers.java, 其实与上面一致

//xml:
<variable
    name="handler"
    type="com.xx.xxx.EventHandlers" />

<Button
     android:layout_width="match_parent"
     android:layout_height="48dp"
     android:onClick="@{handler::click}" />

// UI类:绑定handler,如绑定ViewModel那样
EventHandlers handler = new EventHandlers();
binding.setHandler(handler);

// EventHandlers 执行click事件
public void click(View view){
    //do
}

4. 带参数:@{() -> viewModel.click(obj.id)}

//xml:
<variable
    name="viewModel"
    type="com.xx.xxx.ViewModel" />

<variable
    name="obj"
    type="com.xx.xxx.User" />
<Button
     android:layout_width="match_parent"
     android:layout_height="48dp"
     android:onClick="@{() -> viewModel.click(obj.id)}"
/>

//ViewModel:
public void click(long id){
     //do   
}

5. ObservableField<OnClickListener>

//xml:
  <variable
       name="iconView"
       type="com.xxxxx.IconView" />

  <RelativeLayout
        android:id="@+id/rl_icon_view"
        android:layout_width="match_parent"
        android:layout_height="55dp"
        android:onClick="@{iconView.clickListener}"
       >    

//IconView:
  public final ObservableField<OnClickListener> clickListener=new ObservableField<>();

//xml所在的Activity类:
  binding.iconView.clickListener.set(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
              Toast.makeText(getApplicationContext(),"iconView",Toast.LENGTH_SHORT).show();
         }
  });

6. 带参数

 android:onClick="@{()->loadingModel.chooseLang(2)}"
  public void chooseLang(int language) {
        LogUtil.i(TAG, "language=" + language);

  }

7. 带view的参数

//xml:
<variable
       name="listener"
       type="test.carrie.todomvvmtest.ui.OnTaskItemListener"/> 

android:onClick="@{(view)->listener.onCheckBoxClick(obj,view)}"


//adapter:
 public void onCheckBoxClick(ToDo entity, View v) {

        }
  • 17
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是Kotlin实现RecyclerView并使用databinding的代码示例: 1. 创建RecyclerView的item布局文件,例如item_layout.xml: ``` <layout xmlns:android="http://schemas.android.com/apk/res/android"> <data> <variable name="item" type="com.example.Item" /> </data> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="@{item.text}" /> </layout> ``` 2. 创建RecyclerView的适配器类,例如MyAdapter.kt: ``` class MyAdapter(private val items: List<Item>) : RecyclerView.Adapter<MyAdapter.ViewHolder>() { override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder { val inflater = LayoutInflater.from(parent.context) val binding = ItemLayoutBinding.inflate(inflater, parent, false) return ViewHolder(binding) } override fun onBindViewHolder(holder: ViewHolder, position: Int) { holder.bind(items[position]) } override fun getItemCount(): Int { return items.size } inner class ViewHolder(private val binding: ItemLayoutBinding) : RecyclerView.ViewHolder(binding.root) { fun bind(item: Item) { binding.item = item binding.executePendingBindings() } } } ``` 3. 在布局文件中添加RecyclerView,例如activity_main.xml: ``` <layout xmlns:android="http://schemas.android.com/apk/res/android"> <data> <variable name="viewModel" type="com.example.MainViewModel" /> </data> <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" app:items="@{viewModel.items}" /> </layout> ``` 4. 在MainActivity中使用databinding绑定数据和适配器,例如MainActivity.kt: ``` class MainActivity : AppCompatActivity() { private lateinit var binding: ActivityMainBinding private lateinit var adapter: MyAdapter override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) binding = DataBindingUtil.setContentView(this, R.layout.activity_main) binding.lifecycleOwner = this adapter = MyAdapter(listOf(Item("Item 1"), Item("Item 2"), Item("Item 3"))) binding.recyclerView.adapter = adapter } } ``` 注意,这里使用了自定义属性`app:items`来绑定RecyclerView的数据,需要在布局文件中声明`xmlns:app="http://schemas.android.com/apk/res-auto"`。 希望这个示例能对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值