MVVM DataBinding模式

MVVM設計模式

MVVM避凝,即Model-View-ViewModel,Model提供數(shù)據(jù)恩沽,View負責顯示誊稚,ViewModel跟Model和View進行雙向綁定;當View有用戶輸入后,ViewModel通知Model更新數(shù)據(jù)里伯,同理Model數(shù)據(jù)更新城瞎,ViewModel通知View更新;視圖如下:


DataBinding

Android databind技術采用 mvvm設計模式疾瓮,該設計模式主要分為三個部分:View 脖镀、Model、Viewmodel爷贫。其中View 為用戶定義的layout布局认然、Activity、Fragment等漫萄; Model 為用戶定義的數(shù)據(jù)結構;最重要的Viewmodel由兩部分構成:其一部分邏輯是由DataBinding生成的binding類文件盈匾,其二部分是我們自己寫的XXXModel類文件(即Presenter)腾务,下一篇會詳細闡述。
Android databind技術實現(xiàn)了view -- model之間的綁定削饵,在寫Android界面的時候岩瘦,可以省去大量的findviewbyid( ) 、setOnClickListener( )窿撬、textview.setText( ) 等膠水代碼启昧。該技術的某些高級特性還可以快速的實現(xiàn)添加view屬性。

Gradle配置

android {   
     ....   
     dataBinding {        
       enabled = true   
     }
}

使用Data Binding

我們跟著View-Model-ViewModel模式走一個:
一劈伴、View
使用 Data Binding 之后密末,xml的布局文件就不再單純地展示 UI 元素,還需要定義 UI 元素用到的變量跛璧。所以严里,它的根節(jié)點不再是一個ViewGroup,而是變成了layout追城,并且新增了一個節(jié)點data刹碾。


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

layout中的內容需要在最外層添加 <layout> </layout>。
然后要聲明 <data> 內容座柱,其中<variable>對應的是使用的mvvm中的model,即用戶定義的數(shù)據(jù)結構迷帜。其中 name 聲明變量名,type聲明變量類型色洞。
最后在view的參數(shù)中使用android:text="@{user.lastName}"進行賦值戏锹。

二、Model——User類
添加一個 POJO 類 - User锋玲,非常簡單景用,四個屬性以及他們的 getter 和 setter

public class User {
    private final String firstName;
    private final String lastName;
    private String displayName;
    private int age;
 
    public User(String firstName, String lastName) {
        this.firstName = firstName;
        this.lastName = lastName;
    }
 
    public User(String firstName, String lastName, int age) {
        this(firstName, lastName);
        this.age = age;
    }
 
    public int getAge() {
        return age;
    }
 
    public String getFirstName() {
        return firstName;
    }
 
    public String getLastName() {
        return lastName;
    }
 
    public String getDisplayName() {
        return firstName + " " + lastName;
    }
 
    public boolean isAdult() {
        return age >= 18;
    }
}

三、ViewModel
Android Studio會根據(jù)Layout的名稱自動生成ViewModel類,比如activity_main.xml會自動生成一個ActivityMainBinding類伞插,ActivityMainBinding中的方法割粮,會根據(jù)layout中的屬性自動生成。比如我們在layout中指定了user變量媚污,ActivityMainBinding類中會自動生成setUser方法舀瓢。

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ActivityMainBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
    User user = new User("Test", "User");
    binding.setUser(user);
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市耗美,隨后出現(xiàn)的幾起案子京髓,更是在濱河造成了極大的恐慌,老刑警劉巖商架,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件堰怨,死亡現(xiàn)場離奇詭異,居然都是意外死亡蛇摸,警方通過查閱死者的電腦和手機备图,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來赶袄,“玉大人揽涮,你說我怎么就攤上這事《龇危” “怎么了蒋困?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長敬辣。 經(jīng)常有香客問我雪标,道長,這世上最難降的妖魔是什么购岗? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任汰聋,我火速辦了婚禮,結果婚禮上喊积,老公的妹妹穿的比我還像新娘烹困。我一直安慰自己,他們只是感情好乾吻,可當我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布髓梅。 她就那樣靜靜地躺著,像睡著了一般绎签。 火紅的嫁衣襯著肌膚如雪枯饿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天诡必,我揣著相機與錄音奢方,去河邊找鬼搔扁。 笑死,一個胖子當著我的面吹牛蟋字,可吹牛的內容都是我干的稿蹲。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼鹊奖,長吁一口氣:“原來是場噩夢啊……” “哼苛聘!你這毒婦竟也來了?” 一聲冷哼從身側響起忠聚,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤设哗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后两蟀,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體网梢,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年垫竞,在試婚紗的時候發(fā)現(xiàn)自己被綠了澎粟。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡欢瞪,死狀恐怖,靈堂內的尸體忽然破棺而出徐裸,到底是詐尸還是另有隱情遣鼓,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布重贺,位于F島的核電站骑祟,受9級特大地震影響,放射性物質發(fā)生泄漏磕道。R本人自食惡果不足惜癌蓖,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一虽画、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧缸棵,春花似錦、人聲如沸谭期。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽隧出。三九已至踏志,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胀瞪,已是汗流浹背针余。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人圆雁。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓忍级,卻偏偏與公主長得像,于是被迫代替她去往敵國和親摸柄。 傳聞我的和親對象是個殘疾皇子颤练,可洞房花燭夜當晚...
    茶點故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,075評論 25 707
  • 在 Android 開發(fā)過程中,由于 Android 作為 View 描述的 xml 視圖功能較弱驱负,開發(fā)中很容易寫...
    射覆閱讀 4,238評論 0 22
  • *本篇文章已授權微信公眾號 guolin_blog (郭霖)獨家發(fā)布 什么是MVVM 說到DataBinding嗦玖,...
    帶心情去旅行閱讀 8,601評論 23 91
  • 文/婉兮 1 小時候酪术,我最怕父母提“別人家的孩子”器瘪。 但這個神奇物種無處不在,她存在于成績單里绘雁、活躍在課外活動中橡疼、...
    婉xi閱讀 826評論 4 8
  • (來自爸爸文集--為你而歌) 生活中總有一些人,給人的印象太深刻庐舟,留著腦海里揮之不去欣除,成為永遠的記憶。 比如春妮就...
    是你狗叔叔閱讀 398評論 0 4