DataBinding使用(二)

佈局中添加DataBinding

Data標籤Class屬性

<data class="TestDataBinding2">

生成指定的名稱的Binding對象。

什麼是Bind對象呢?來回顧之前的一句代碼

ViewDataBinding mBinder = DataBindingUtil.setContentView(this, R.layout.activity_main);

默認情況是這樣的。如果我們設置了data標籤的class屬性,系統會自動幫助我們生成一個ViewDataBinding的子類,幫助我們操作xml中綁定的數據

 

class屬性就是幫助我們改變生成的類名和位置,用法有:

<data class="TestDataBinding2"></data>

在模塊封裝包中會生成名爲TestBinding的Binding類。

<data class="com.example.TestDataBinding2"></data>

在指定的包下生成Binding類。

 

那生成的TestDataBinding2 與 ViewDataBinding 之間有什麼區別呢? 
最大的區別的就在於TestDataBinding2中爲設置的variable生成了setter 和 getter方法,設置綁定數據更加簡便。

import com.lisn.mywanandroid.databinding.TestDataBinding2;

public class DataBinding2Activity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        TestDataBinding2 mBinding = DataBindingUtil.setContentView(this, R.layout.activity_data_binding2);
        User user = new User();
        user.name = "hhhhh";
        mBinding.setUser(user);
        mBinding.setListener(new TestClickListener());
    }

    public static void startActivity(Activity activity) {
        activity.startActivity(new Intent(activity, DataBinding2Activity.class));
    }

    public class TestClickListener {
        public void onClickListenerBinding() {
            Toast.makeText(DataBinding2Activity.this, "BindingClick", Toast.LENGTH_SHORT).show();
        }
    }
}

data的子標籤

variable 它用來綁定具體的對象類
<variable
 name="user"
 type="com.lisn.mywanandroid.DataBinding.User" />

import  用來導入引用對象

        <import type="com.lisn.mywanandroid.Ui.Activity.DataBinding2Activity.TestClickListener" />

        <variable
            name="listener"
            type="TestClickListener" />

如果引用兩個相同類名怎麼辦 ?

可以使用 alias 別名屬性

<data>

    <import
        type="com.lisn.myapplication.bean.User" />

    <import
        type="com.lisn.myapplication.User"
        alias="User2" />

</data>

如何使用data中引入和定義的內容

 <TextView
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:text="@{user.name,default=name}"
  android:textAllCaps="false" />

 <Button
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:onClick="@{()->listener.onClickListenerBinding()}"
  android:textAllCaps="false" />

使用variable中的bean對象,如果是屬性,直接使用@{name.field}

例如:android:text="@{user.name}"

android:text="@{user.name,default=name}"   這句中的default屬性,是爲了頁面佈局開發預覽顯示方便而提供的,項目真正運行時不會顯示,和佈局中的  tools:text="預覽"  類似。

如果使用的無參數方法,@{() -> name.function()}

點擊事件需要把點擊的view傳入並操作,@{(v) -> name.function(v)}

括號中間的v就表示當前的這個view的參數名稱(可以自定義),直接作爲參數名使用就可以。

import

使用import引入的工具類,@{util.function()}

<TextView
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:text="@{Utility.autoAppend(user.name)}" />

Includes的使用

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:bind="http://schemas.android.com/apk/res-auto">
   <data>
       <variable name="user" type="com.example.User"/>
   </data>
   <LinearLayout
       android:orientation="vertical"
       android:layout_width="match_parent"
       android:layout_height="match_parent">
       <include layout="@layout/name"
           bind:user="@{user}"/>
       <include layout="@layout/contact"
           bind:user="@{user}"/>
   </LinearLayout>
</layout>

系統會自動生成一個自定義屬性bind,通過bind可以直接對include中的layout中綁定的數據直接進行賦值,這樣就可以間接的控制include中的操作。

ViewStub

binding = DataBindingUtil.setContentView(this, R.layout.activity_view_stub);
binding.viewStub.setOnInflateListener(new ViewStub.OnInflateListener() {
    @Override
    public void onInflate(ViewStub stub, View inflated) {
        ViewStubBinding binding = DataBindingUtil.bind(inflated);
        User user = new User("fee", "lang");
        binding.setUser(user);
    }
});

分析上面的代碼,首先ViewStub在尚未添加到xml中時,獲取Bindgin對象肯定是無效的,所以需要在OnInflateListener中回調被添加的事件,然後再去獲Bing對象。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章