Android MVVM模式DataBinding使用簡單說明

前言

MVC是Model-View-Controller的縮寫盔腔,它將應(yīng)用程序劃分為三個(gè)部分:

Model: 模型(用于封裝與應(yīng)用程序的業(yè)務(wù)邏輯相關(guān)的數(shù)據(jù)以及對數(shù)據(jù)的處理方法)

View: 視圖(渲染頁面)

Controller: 控制器(M和V之間的連接器在岂,用于控制應(yīng)用程序的流程顶瞳,及頁面的業(yè)務(wù)邏輯)

MVC優(yōu)點(diǎn):實(shí)現(xiàn)關(guān)注點(diǎn)分離猎荠,即應(yīng)用程序中的數(shù)據(jù)模型與業(yè)務(wù)和展示邏輯解耦娱俺。在客戶端開發(fā)中裹驰,就是將模型(M-數(shù)據(jù)派撕、操作數(shù)據(jù))婉弹、視圖(V-顯示數(shù)據(jù)的HTML元素)之間實(shí)現(xiàn)代碼分離,松散耦合终吼,使之成為一個(gè)更容易開發(fā)镀赌、維護(hù)和測試的客戶端應(yīng)用程序。

MVC缺點(diǎn):

不適合小型际跪,中等規(guī)模的應(yīng)用程序商佛,花費(fèi)大量時(shí)間將MVC應(yīng)用到規(guī)模并不是很大的應(yīng)用程序通常會得不償失喉钢。

視圖與控制器間過于緊密連接,視圖與控制器是相互分離良姆,但卻是聯(lián)系緊密的部件肠虽,視圖沒有控制器的存在,其應(yīng)用是很有限的玛追,反之亦然税课,這樣就妨礙了他們的獨(dú)立重用。

視圖對模型數(shù)據(jù)的低效率訪問痊剖,依據(jù)模型操作接口的不同韩玩,視圖可能需要多次調(diào)用才能獲得足夠的顯示數(shù)據(jù)。對未變化數(shù)據(jù)的不必要的頻繁訪問陆馁,也將損害操作性能

MVP(Model-View-Presenter)是MVC的改良模式找颓,由IBM的子公司Taligent提出。和MVC的相同之處在于:Controller/Presenter負(fù)責(zé)業(yè)務(wù)邏輯叮贩,Model管理數(shù)據(jù)叮雳,View負(fù)責(zé)顯示只不過是將 Controller 改名為 Presenter,同時(shí)改變了通信方向妇汗。


MVP特點(diǎn):

M、V说莫、P之間雙向通信杨箭。

View 與 Model 不通信,都通過 Presenter 傳遞储狭。Presenter完全把Model和View進(jìn)行了分離互婿,主要的程序邏輯在Presenter里實(shí)現(xiàn)。

View 非常薄辽狈,不部署任何業(yè)務(wù)邏輯慈参,稱為”被動(dòng)視圖”(Passive View),即沒有任何主動(dòng)性刮萌,而 Presenter非常厚驮配,所有邏輯都部署在那里。

Presenter與具體的View是沒有直接關(guān)聯(lián)的着茸,而是通過定義好的接口進(jìn)行交互壮锻,從而使得在變更View時(shí)候可以保持Presenter的不變,這樣就可以重用涮阔。不僅如此猜绣,還可以編寫測試用的View,模擬用戶的各種操作敬特,從而實(shí)現(xiàn)對Presenter的測試–從而不需要使用自動(dòng)化的測試工具掰邢。

MVP優(yōu)點(diǎn):

模型與視圖完全分離牺陶,我們可以修改視圖而不影響模型;

可以更高效地使用模型辣之,因?yàn)樗械慕换ザ及l(fā)生在一個(gè)地方——Presenter內(nèi)部掰伸;

我們可以將一個(gè)Presenter用于多個(gè)視圖,而不需要改變Presenter的邏輯召烂。這個(gè)特性非常的有用碱工,因?yàn)橐晥D的變化總是比模型的變化頻繁;

如果我們把邏輯放在Presenter中奏夫,那么我們就可以脫離用戶接口來測試這些邏輯(單元測試)怕篷。

MVP缺點(diǎn):

視圖和Presenter的交互會過于頻繁,使得他們的聯(lián)系過于緊密酗昼。也就是說廊谓,一旦視圖變更了,presenter也要變更麻削。


MVVMModel-View-ViewModel的簡寫蒸痹。主要目的是分離視圖(View)和模型(Model)

MVVM優(yōu)點(diǎn)

低耦合,視圖(View)可以獨(dú)立于Model變化和修改呛哟,一個(gè)ViewModel可以綁定到不同的”View”上叠荠,當(dāng)View變化的時(shí)候Model可以不變,當(dāng)Model變化的時(shí)候View也可以不變扫责。

可重用性榛鼎,可以把一些視圖邏輯放在一個(gè)ViewModel里面,讓很多view重用這段視圖邏輯鳖孤。

獨(dú)立開發(fā)者娱,開發(fā)人員可以專注于業(yè)務(wù)邏輯和數(shù)據(jù)的開發(fā)(ViewModel),設(shè)計(jì)人員可以專注于頁面設(shè)計(jì)苏揣,使用Expression Blend可以很容易設(shè)計(jì)界面并生成xml代碼黄鳍。

可測試,界面向來是比較難于測試的平匈,而現(xiàn)在測試可以針對ViewModel來寫框沟。


DataBinding是Google在2015年7月發(fā)布的Android Studio v1.3.0 版本上引入的,在2016年4月Android Studio v2.0.0 上正式支持增炭。引入之初街望,不支持雙向綁定,目前已經(jīng)支持了弟跑。

DataBinding 是基于MVVM思想實(shí)現(xiàn)數(shù)據(jù)和UI綁定的的框架灾前,有了 Data Binding,在Android中也可以很方便的實(shí)現(xiàn)MVVM孟辑。

在引入DataBinding之前哎甲,我們需要敲很多很雞肋的代碼蔫敲,如 findViewById()、setText()炭玫,setVisibility()奈嘿,setEnabled() 或 setOnClickListener() 等,通過 Data Binding , 我們可以通過聲明式布局以精簡的代碼來綁定應(yīng)用程序邏輯和布局吞加,這樣就不用編寫大量的毫無營養(yǎng)的代碼了裙犹。

DataBinding使用

1、在使用的module的build.gradle中加入

android {

? ? ? ?dataBinding {

? ? ? ? enabled true

? ? }

}


2衔憨、數(shù)據(jù)類

可用ObservableField叶圃,也可以用LiveData,官方推薦LiveData践图,LiveData會遵從其他應(yīng)用組件(如activity掺冠,fragment)的生命周期,它只會在UI組件處在active狀態(tài)(如activity處在started和resumed?)時(shí)才會推送數(shù)據(jù)码党。這樣避免了我們UI展示數(shù)據(jù)時(shí)德崭,需要檢查下組件是否存在。具體后續(xù)說明揖盘。這里demo用的ObservableField.眉厨。

public class UserBean {

public ObservableFieldname =new ObservableField<>();

? ? public ObservableFieldage =new ObservableField<>();

? ? public ObservableFieldsex =new ObservableField<>();

}


3、布局文件

布局文件根標(biāo)簽是layout兽狭。layout中包含data標(biāo)簽缺猛,以及view。data部分是對應(yīng)使用model椭符。import說明是哪個(gè)具體的數(shù)據(jù)類,可定義alias 別名耻姥。variable定義變量销钝,給view中引用,type為變量的類型琐簇。

4蒸健、在activity中使用

MainMvvmBinding 這個(gè)是根據(jù)布局文件自動(dòng)生成的,布局文件命名為main_mvvm婉商,則生成MainMvvmBinding似忧,如果命名為activity_main,則生成ActivityMainBinding丈秩。

```

public class MainActivityextends AppCompatActivity {

private MainMvvmBinding binding;

? ? @Override

? ? protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

? ? ? ? binding = DataBindingUtil.setContentView(this, R.layout.main_mvvm);

? ? ? ? UserBean userBean =new UserBean();

? ? ? ? userBean.name.set("張三");

? ? ? ? userBean.age.set(28);

? ? ? ? userBean.sex.set("男");

? ? ? ? binding.setUser(userBean);

? ? }

}

```

項(xiàng)目demo代碼可見:https://github.com/feb07/MVVMProject

總結(jié)

通過dataBinding 實(shí)現(xiàn)mvvm模式盯捌,使得數(shù)據(jù)和UI綁定,代碼更加簡潔蘑秽,大大的減少了代碼量饺著。通過 Data Binding , 我們可以通過聲明式布局以精簡的代碼來綁定應(yīng)用程序邏輯和布局箫攀。期待在項(xiàng)目中的使用~~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市幼衰,隨后出現(xiàn)的幾起案子靴跛,更是在濱河造成了極大的恐慌,老刑警劉巖渡嚣,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件梢睛,死亡現(xiàn)場離奇詭異,居然都是意外死亡识椰,警方通過查閱死者的電腦和手機(jī)绝葡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來裤唠,“玉大人挤牛,你說我怎么就攤上這事≈终海” “怎么了墓赴?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長航瞭。 經(jīng)常有香客問我诫硕,道長,這世上最難降的妖魔是什么刊侯? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任章办,我火速辦了婚禮,結(jié)果婚禮上滨彻,老公的妹妹穿的比我還像新娘藕届。我一直安慰自己,他們只是感情好亭饵,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布休偶。 她就那樣靜靜地躺著,像睡著了一般辜羊。 火紅的嫁衣襯著肌膚如雪踏兜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天八秃,我揣著相機(jī)與錄音碱妆,去河邊找鬼。 笑死昔驱,一個(gè)胖子當(dāng)著我的面吹牛疹尾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼航棱,長吁一口氣:“原來是場噩夢啊……” “哼睡雇!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起饮醇,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤它抱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后朴艰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體观蓄,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年祠墅,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了侮穿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,688評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡毁嗦,死狀恐怖亲茅,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情狗准,我是刑警寧澤克锣,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站腔长,受9級特大地震影響袭祟,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜捞附,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一巾乳、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧鸟召,春花似錦胆绊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至槽片,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間肢础,已是汗流浹背还栓。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留传轰,地道東北人剩盒。 一個(gè)月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像慨蛙,于是被迫代替她去往敵國和親辽聊。 傳聞我的和親對象是個(gè)殘疾皇子纪挎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評論 2 353

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