本教程是跟著 Data Binding Guide 學習過程中得出的一些實踐經驗,同時修改了官方教程的一些錯誤,每一個知識點都有對應的源碼,爭取做到實踐與理論相結合。
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供無極網站建設、無極做網站、無極網站設計、無極網站制作等企業(yè)網站建設、網頁設計與制作、無極企業(yè)網站模板建站服務,十年無極做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。
Data Binding 解決了 Android UI 編程中的一個痛點,官方原生支持 MVVM 模型可以讓我們在不改變既有代碼框架的前提下,非常容易地使用這些新特性。其實在此之前,已經有些第三方的框架可以支持 MVVM 模型,無耐由于框架的侵入性太強,導致一直沒有流行起來。
準備
Android Studio 更新到 1.3 版本
打開 Preferences,找到 Appearances & Behavior 下的 Updates 選項,把 Automatically Check updates for 修改成 Canary Channel。
注意
Data Binding 是一個 support 包,因此與 Android M 沒什么關系,可以不用下載 Android MNC Preview 的 SDK。
新建一個 Project
修改 Project 的 build.gradle,為 build script 添加一條依賴,Gradle 版本為 1.2.3。
classpath 'com.android.tools.build:gradle:1.2.3' classpath 'com.android.databinding:dataBinder:1.0-rc0'
為用到 Data Binding 的模塊添加插件,修改對應的 build.gradle。
apply plugin: 'com.android.databinding'
注意
如果 Module 用到的 buildToolsVersion 高于 22.0.1,比如 23 rc1,那 com.android.databinding:dataBinder 的版本要改為 1.3.0-beta1,否則會出現(xiàn)如下錯誤:
基礎
工程創(chuàng)建完成后,我們通過一個最簡單的例子來說明 Data Binding 的基本用法。
布局文件
使用 Data Binding 之后,xml的布局文件就不再單純地展示 UI 元素,還需要定義 UI 元素用到的變量。所以,它的根節(jié)點不再是一個 ViewGroup,而是變成了 layout,并且新增了一個節(jié)點 data。
<layout xmlns:android="http://schemas.android.com/apk/res/android"> <data> </data> <!--原先的根節(jié)點(Root Element)--> <LinearLayout> .... </LinearLayout> </layout>
要實現(xiàn) MVVM 的 ViewModel 就需要把數(shù)據與UI進行綁定,data 節(jié)點就為此提供了一個橋梁,我們先在 data 中聲明一個 variable,這個變量會為 UI 元素提供數(shù)據(例如 TextView 的 android:text),然后在 Java 代碼中把”后臺”數(shù)據與這個 variable 進行綁定。
如果要用一個表格來展示用戶的基本信息,用 Data Binding 應該怎么實現(xiàn)呢?
數(shù)據對象
添加一個 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; } }
稍后,我們會新建一個 User 類型的變量,然后把它跟布局文件中聲明的變量進行綁定。
定義 Variable
再回到布局文件,在 data 節(jié)點中聲明一個變量 user。
<data> <variable name="user" type="com.liangfeizc.databindingsamples.basic.User" /> </data>
其中 type 屬性就是我們在 Java 文件中定義的 User 類。
當然,data 節(jié)點也支持 import,所以上面的代碼可以換一種形式來寫。
<data> <import type="com.liangfeizc.databindingsamples.basic.User" /> <variable name="user" type="User" /> </data>
然后我們剛才在 build.gradle 中添加的那個插件 - com.android.databinding會根據xml文件的名稱 Generate 一個繼承自 ViewDataBinding 的類。
例如,這里 xml 的文件名叫 activity_basic.xml,那么生成的類就是 ActivityBasicBinding。
注意
java.lang.* 包中的類會被自動導入,可以直接使用,例如要定義一個 String 類型的變量:
<variable name="firstName" type="String" />
綁定 Variable
修改 BasicActivity 的 onCreate 方法,用 DatabindingUtil.setContentView() 來替換掉 setContentView(),然后創(chuàng)建一個 user 對象,通過 binding.setUser(user) 與 variable 進行綁定。
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); ActivityBasicBinding binding = DataBindingUtil.setContentView( this, R.layout.activity_basic); User user = new User("fei", "Liang"); binding.setUser(user); }
注意
ActivityBasicBinding 類是自動生成的,所有的 set 方法也是根據 variable 名稱生成的。例如,我們定義了兩個變量。
<data> <variable name="firstName" type="String" /> <variable name="firstName" type="" </data>
那么就會生成對應的兩個 set 方法。
setFirstName(String firstName); setLastName(String lastName);
使用 Variable
數(shù)據與 Variable 綁定之后,xml 的 UI 元素就可以直接使用了。
<TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@{user.lastName}" />
至此,一個簡單的數(shù)據綁定就完成了,可參考完整代碼
高級用法
使用類方法
首先為類添加一個靜態(tài)方法
public class MyStringUtils { public static String capitalize(final String word) { if (word.length() > 1) { return String.valueOf(word.charAt(0)).toUpperCase() + word.substring(1); } return word; } }
然后在 xml 的 data 節(jié)點中導入:
<import type="com.liangfeizc.databindingsamples.utils.MyStringUtils" />
使用方法與 Java 語法一樣:
<TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@{StringUtils.capitalize(user.firstName)}" />
類型別名
如果我們在 data 節(jié)點了導入了兩個同名的類怎么辦?
<import type="com.example.home.data.User" /> <import type="com.examle.detail.data.User" /> <variable name="user" type="User" />
這樣一來出現(xiàn)了兩個 User 類,那 user 變量要用哪一個呢?不用擔心,import 還有一個 alias 屬性。
<import type="com.example.home.data.User" /> <import type="com.examle.detail.data.User" alias="DetailUser" /> <variable name="user" type="DetailUser" />
Null Coalescing 運算符
android:text="@{user.displayName ?? user.lastName}"
就等價于
android:text="@{user.displayName != null ? user.displayName : user.lastName}"
屬性值
通過 ${} 可以直接把 Java 中定義的屬性值賦值給 xml 屬性。
<TextView android:text="@{user.lastName}" android:layout_width="wrap_content" android:layout_height="wrap_content" android:visibility="@{user.isAdult ? View.VISIBLE : View.GONE}"/>
使用資源數(shù)據
這個例子,官方教程有錯誤,可以參考Android Data Binder 的一個bug,完整代碼在此。
<TextView android:padding="@{large? (int)@dimen/largePadding : (int)@dimen/smallPadding}" android:background="@android:color/black" android:textColor="@android:color/white" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/hello_world" />
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
本文題目:詳解Android的MVVM框架-數(shù)據綁定
網頁路徑:http://aaarwkj.com/article42/jpojhc.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供服務器托管、虛擬主機、移動網站建設、網站建設、網站內鏈、搜索引擎優(yōu)化
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)