Jetpack使用(ViewModel橄镜、LiveData偎快、DataBinding)

背景:

Jetpack是安卓官方為了簡化代碼,提高開發(fā)者開發(fā)效率的一系列庫洽胶。

這里只是入門晒夹,只涉及到:ViewModel,LiveData和Binding的基礎(chǔ)使用姊氓。

他們?nèi)齻€可以簡化Controller(即MainActivity)的代碼量丐怯,減少了代碼的冗余度。下面幾張圖片是其作用翔横。




一:ViewModel

作用:將View(界面)中的數(shù)據(jù)進行單獨管理读跷,是控制器變得更加簡單。

????????????還可以在軟件Destroy的情況下可以保存數(shù)據(jù)禾唁,不需要像之前那樣去手動管理數(shù)據(jù)效览。

????????????可以與LiveData配合使用无切。

1.在包中創(chuàng)建一個ViewModel類。



代碼

2.在MainActivity中

MyViewModel myViewModel;


下面是將Activity與MyViewModel建立聯(lián)系丐枉,實例化哆键。

在創(chuàng)建ViewModel的對象時,使用第一種方法瘦锹,“this”會出錯籍嘹。使用第二種方法則不會。

上面兩句其實都可以用M湓骸H枋俊!但是不知道為啥有時會出錯


如果這里是繼承Avtivity類听绳,不僅這里的this會出錯颂碘,就連下面LiveData里聲明觀察者時,用到的this都會出錯椅挣!

查到的解釋:AppCompatActivity ,首先從名字上來看,是compat系列中的一員,和ViewCompat,ContextCompat一樣,是提供向下兼容功能的Activity.

3.使用

直接調(diào)用其中創(chuàng)建的數(shù)據(jù)凭涂,用來改變,或者顯示在TextView中贴妻。

具體代碼見項目:ViewModelTest2這個項目切油。真的是一路磕磕絆絆,才實現(xiàn)名惩。澎胡。。哎娩鹉。



二.LiveData的使用

負責暫存數(shù)據(jù)攻谁,數(shù)據(jù)更改的時候通知視圖。

Mutable 可變的

module??模塊; 功能塊; 程序塊; 組件; 配件;

1.在ViewModel中創(chuàng)建弯予。戚宦。。锈嫩。因為他經(jīng)常和ViewModel一起配合使用

2.使用




三受楼、DataBinding

DataBinding 是谷歌官方發(fā)布的一個框架,顧名思義即為數(shù)據(jù)綁定呼寸,是 MVVM 模式在 Android 上的一種實現(xiàn)艳汽,用于降低布局和邏輯的耦合性,使代碼邏輯更加清晰对雪。MVVM 相對于 MVP河狐,其實就是將 Presenter 層替換成了 ViewModel 層。

DataBinding 能夠省去我們一直以來的 findViewById() 步驟,大量減少 Activity 內(nèi)的代碼馋艺,數(shù)據(jù)能夠單向或雙向綁定到 layout 文件中栅干,有助于防止內(nèi)存泄漏,而且能自動進行空檢測以避免空指針異常捐祠。

要實現(xiàn) MVVM 的 ViewModel 就需要把數(shù)據(jù)(Model)與 UI(View)進行綁定非驮,data?標簽的作用就像一個橋梁搭建了 View 和 Model 之間的通道

1.準備工作


在gradle app中的默認設(shè)置中添加一段話,打開databinding

寫好后雏赦,sync,即同步以下gradle

2.? 轉(zhuǎn)換為databinding布局

轉(zhuǎn)換之后的樣子:

4.系統(tǒng)自動生成了ActivityMainBinding類芙扎,由acticity_main轉(zhuǎn)換為databinding后生成星岗。


5.使activity_main與MainActivity重新關(guān)聯(lián)

這樣之后呢,binding就可以直接調(diào)用布局文件中的TextView和Button了戒洼,比如:binding.button


以上是將布局中的控件綁定到頁面俏橘。

現(xiàn)在將頁面中的反綁到布局。

目前是這樣的:


開始反綁:




將TextView的setText這里圈浇,改寫為上圖:

data在這里即代表MyViewModel寥掐,可以調(diào)用其中的數(shù)據(jù)number,轉(zhuǎn)換為字符串后磷蜀,顯示再TextView中去召耘。

同理,再Button這里:

添加語句:

()->含義是呼叫函數(shù)

這樣褐隆,一旦這個button被點擊污它,就會自動調(diào)用 這里的onClick,從而調(diào)用add()庶弃。

在頁面中就不需要再去setClickLisner了衫贬。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市歇攻,隨后出現(xiàn)的幾起案子固惯,更是在濱河造成了極大的恐慌,老刑警劉巖缴守,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件葬毫,死亡現(xiàn)場離奇詭異,居然都是意外死亡屡穗,警方通過查閱死者的電腦和手機供常,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鸡捐,“玉大人栈暇,你說我怎么就攤上這事」烤担” “怎么了源祈?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵煎源,是天一觀的道長。 經(jīng)常有香客問我香缺,道長手销,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任图张,我火速辦了婚禮锋拖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘祸轮。我一直安慰自己兽埃,他們只是感情好,可當我...
    茶點故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布适袜。 她就那樣靜靜地躺著柄错,像睡著了一般。 火紅的嫁衣襯著肌膚如雪苦酱。 梳的紋絲不亂的頭發(fā)上售貌,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天,我揣著相機與錄音疫萤,去河邊找鬼颂跨。 笑死,一個胖子當著我的面吹牛扯饶,可吹牛的內(nèi)容都是我干的毫捣。 我是一名探鬼主播,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼帝际,長吁一口氣:“原來是場噩夢啊……” “哼蔓同!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蹲诀,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤斑粱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后脯爪,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體则北,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年痕慢,在試婚紗的時候發(fā)現(xiàn)自己被綠了尚揣。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,144評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡掖举,死狀恐怖快骗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤方篮,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布名秀,位于F島的核電站,受9級特大地震影響藕溅,放射性物質(zhì)發(fā)生泄漏匕得。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一巾表、第九天 我趴在偏房一處隱蔽的房頂上張望汁掠。 院中可真熱鬧,春花似錦集币、人聲如沸考阱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至负间,卻和暖如春偶妖,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背政溃。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工趾访, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人董虱。 一個月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓扼鞋,卻偏偏與公主長得像,于是被迫代替她去往敵國和親愤诱。 傳聞我的和親對象是個殘疾皇子云头,可洞房花燭夜當晚...
    茶點故事閱讀 45,092評論 2 355

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