DataBinding與LiveData雙向綁定

LiveData在單獨(dú)使用時(shí)蔓彩,想要在數(shù)據(jù)變化時(shí)通知View需要設(shè)置一個(gè)監(jiān)聽

liveData.observe(this, new Observer<String>() {
    @Override
    public void onChanged(String s) {
        
    }
});

而我們通常是在ViewModel中持有LiveData的引導(dǎo)治笨,而ViewModel中不能持有View的引用,這就很糾結(jié)赤嚼。查閱官方文檔了解到旷赖。從Android Studio3.1開始,支持DataBinding自動(dòng)綁定ViewModel更卒。這樣在數(shù)據(jù)變化時(shí)等孵,就不用手動(dòng)設(shè)置監(jiān)聽來(lái)對(duì)View進(jìn)行相應(yīng)的變化。

下面講下要怎么做

首先定義一個(gè)ViewModel持有LiveData

public class MyViewModel extends ViewModel {
    MutableLiveData<String> liveData;

    public MutableLiveData<String> getName() {
        if (liveData == null) {
            liveData = new MutableLiveData<>();
        }
        return liveData;
    }

    public void setName(String name) {
        if (liveData == null) {
            liveData = new MutableLiveData<>();
        }
        liveData.setValue(name);
    }
}

在Activity的OnCreate中初始化

public class MainActivity extends AppCompatActivity {

    ActivityMainBinding binding;

    MyViewModel viewModel;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
        binding.setLifecycleOwner(this);
        binding.setMainActivity(this);

        viewModel = ViewModelProviders.of(this).get(MyViewModel.class);
        viewModel.setName("aaa");
        binding.setViewModel(viewModel);
    }


    public void onButtonClick() {
        viewModel.setName("bbb");
    }
}

這里給binding設(shè)置了一個(gè)LifecycleOwner蹂空「┟龋可以想象到binding內(nèi)部使用這個(gè)LifecycleOwner給liveData設(shè)置了監(jiān)聽。

在xml中

<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    tools:context=".MainActivity">

    <data>
        <variable
            name="MainActivity"
            type="com.qianfanyun.databinding.MainActivity" />

        <variable
            name="viewModel"
            type="com.qianfanyun.databinding.MyViewModel"/>
    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:gravity="center_horizontal"
        android:orientation="vertical">

        <Button
            android:id="@+id/button"
            android:layout_width="200dp"
            android:layout_height="wrap_content"
            android:text="@={viewModel.name}"
            android:onClick="@{()->MainActivity.onButtonClick()}"
             />

    </LinearLayout>
</layout>

這里給Button設(shè)置了一個(gè)點(diǎn)擊事件上枕,點(diǎn)擊后會(huì)改變liveData的值咐熙,然后會(huì)發(fā)現(xiàn)Button的text變成了bbb。說(shuō)明綁定成功了辨萍。

另外嘗試了View綁定Data棋恼,與普通的綁定相同,在@與{之間加個(gè)=分瘦,也是可以成功的蘸泻,這里就不多說(shuō)了。

參考

Bind layout views to Architecture Components

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末嘲玫,一起剝皮案震驚了整個(gè)濱河市悦施,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌去团,老刑警劉巖抡诞,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件穷蛹,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡昼汗,警方通過(guò)查閱死者的電腦和手機(jī)肴熏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)顷窒,“玉大人蛙吏,你說(shuō)我怎么就攤上這事⌒” “怎么了鸦做?”我有些...
    開封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)谓着。 經(jīng)常有香客問(wèn)我泼诱,道長(zhǎng),這世上最難降的妖魔是什么赊锚? 我笑而不...
    開封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任治筒,我火速辦了婚禮,結(jié)果婚禮上舷蒲,老公的妹妹穿的比我還像新娘耸袜。我一直安慰自己,他們只是感情好阿纤,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開白布句灌。 她就那樣靜靜地躺著夷陋,像睡著了一般欠拾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上骗绕,一...
    開封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天藐窄,我揣著相機(jī)與錄音,去河邊找鬼酬土。 笑死荆忍,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的撤缴。 我是一名探鬼主播刹枉,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼屈呕!你這毒婦竟也來(lái)了微宝?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤虎眨,失蹤者是張志新(化名)和其女友劉穎蟋软,沒(méi)想到半個(gè)月后镶摘,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡岳守,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年凄敢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片湿痢。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡涝缝,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出譬重,到底是詐尸還是另有隱情俊卤,我是刑警寧澤,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布害幅,位于F島的核電站消恍,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏以现。R本人自食惡果不足惜狠怨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望邑遏。 院中可真熱鬧佣赖,春花似錦、人聲如沸记盒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)纪吮。三九已至俩檬,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間碾盟,已是汗流浹背棚辽。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留冰肴,地道東北人屈藐。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像熙尉,于是被迫代替她去往敵國(guó)和親联逻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容