為何使用
上手了這個MVVM框架之后感覺代碼規(guī)整了很多找默,其中,事件和元素的綁定矢门、元素的內(nèi)容和屬性傳值等這一過程都可以完全放進xml里去了攘须,不需要不斷的findview然后set各種listener摧扇,activity部分如釋重負[開心地呼一口氣
解鎖技能
1.元素綁定
之前為了解放繁瑣的findview圣贸,采用了butterknife[其實也是蠻好用的=。=]扛稽,目前打算全部采用了databinding進行綁定了吁峻,以下進行幾點對比
databinding只要將setContentView替換成如下形式
ActivityMainBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
binding中就可以直接調(diào)用layout中所有的帶有id的元素,元素的對象名即id名在张,
binding.imageView
無需進行一一聲明用含,這一點相較于butterknife實在是便捷了不少,之前采用butterknife會在activity開頭進行一系列bindview的對象聲明
2.數(shù)據(jù)和事件綁定
databinding采用對象傳遞的方式將數(shù)據(jù)或者事件傳遞進xml中進行綁定
xml部分形如
<layout xmlns:android="http://schemas.android.com/apk/res/android">
? ? ? ?<data>
? ? ? ? ? ? <variable name="[對象名]" type="[類型的具體class路徑]">
? ? ? ?</data>
<!-- 省略布局內(nèi)容 -->
</layout>
其中對象分為數(shù)據(jù)封裝對象帮匾,和事件的封裝對象
數(shù)據(jù)綁定
數(shù)據(jù)對象形如
public class User{
? ? ? public final String name;
? ? ? public final int age;
}
相應(yīng)的綁定對應(yīng)到xml文件里
<TextView
? ? ? ?android:id="@+id/textview"
? ? ? ?android:layout_width="wrap_content"
? ? ? ?android:layout_height="wrap_content"
? ? ? ?android:text="@{user.name}"/>
事件綁定
事件封裝對象形如
public class Handler{
? ?public void onMyButtonClick(View v){}
}
相應(yīng)的綁定對應(yīng)到xml文件里
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="login"
android:onClick="@{handlers.onMyButtonClick}" />
事件綁定這里需要注意的是事件函數(shù)需要保持特定的形式
比如點擊事件啄骇,就需要與OnClickListener里的onClick函數(shù)參數(shù)的傳遞保持一致,不然會發(fā)生編譯錯誤瘟斜,[butterknife就相對隨意了
3.list數(shù)據(jù)拋棄adapter
list數(shù)據(jù)的渲染一般采用ListView或者RecyclerView缸夹,都需要setAdapter進行相應(yīng)的item處理展示,使用data binding以后螺句,可以拋棄adapter了
主要通過viewmodel來進行
<android.support.v7.widget.RecyclerView
? ? ? ? android:layout_width="match_parent"
? ? ? ? android:layout_height="match_parent"
? ? ? ? app:layoutManager="@{LayoutManagers.linear()}"
? ? ? ? app:items="@{viewModel.items}"
? ? ? ? app:itemView="@{viewModel.itemView}">
view model如下
public classViewModel{
public final ObservableList<User>items=new ObservableArrayList<>();
public final ItemView itemView= ItemView.of(BR.item, R.layout.item_user);
}
其中item_user是每個單項的布局文件
聲明了名為item的variable[可以自定義]虽惭,此處type為User,然后使用item進行相應(yīng)賦值
如果有多種樣式的布局蛇尚,那么就需要把ItemView換成ItemViewSelector
其實這么做有一個問題芽唇,目前每一個單項的binding里通過viewmodel只能傳遞進去user,如果想要進一步的事件綁定等更多的對象就存在問題取劫,
有一個解決方案是將你需要的全都封裝到user里[即傳遞進去的item的variable]
更好的解決方案我再看看[沒錯我就是不想寫adapter
4.databinding的嵌套
[手動探索黨的花式玩]
在采用databinding處理原先的include問題時遇到的匆笤,當所需渲染的數(shù)據(jù)在include里時,data不應(yīng)該在當前的layout下聲明谱邪,要放在include里疚膊,并且include的布局文件也應(yīng)是一個databinding的layout
形如:
父layout
<layout>
? ? ? <include layout="@layout/bottombar"
? ? ? ? ? ? android:id="@+id/include">
</layout>
bottombar
<layout>
? ? ? ?<data>
? ? ? ? ? ?<variable name="handlers" type="[your type]">
? ? ? ?</data>
</layout>
然后在activity中進行DataBindingUtil.setContentView得到主binding對象,binding.include就是include中所包含的binding對象了虾标,此處為
BottombarBinding binding1 = binding.include;
然后binding1.setHandlers就可以了[也很方便啊
也有第二種方案寓盗,variable可以逐層傳遞灌砖,
父layout
<layout>
? ? ? ? <data>
? ? ? ? ? ? ?<variable name="handlers" type="[your type]">
? ? ? ? </data>
? ? ? ? <include layout="@layout/bottombar" bind:handlers="@{handlers}">
</layout>
5.關(guān)于雙向綁定
目前官方的是純粹的單向綁定,聽說有一種在官方文檔上沒有給出來的方法
將@{}換成@={}就可以傀蚌,[測試失敾浴]可能是什么的版本問題=。=善炫,坐等官方填坑
[哦撩幽,沒錯,我不想自己手動雙向
6.進一步偷懶
由于圖片加載等一系列涉及到復(fù)雜操作的箩艺,想要直接通過這種方式處理[偷懶]有些問題窜醉,打算重寫組件,通過attr獲取databinding傳遞的數(shù)據(jù)然后進行相應(yīng)操作艺谆,