Android視圖綁定方法深入探究
視圖綁定
用于替代findViewById的方式獲取id元素, google推薦使用
原理
啟用視圖綁定之后,系統(tǒng)會(huì)為該模塊中的每個(gè) XML 布局文件生成一個(gè)綁定類。綁定類的實(shí)例包含對在相應(yīng)布局中具有 ID 的所有視圖的直接引用。
優(yōu)點(diǎn)(相比于findViewById)
- Null 安全:由于視圖綁定會(huì)創(chuàng)建對視圖的直接引用,因此不存在因視圖 ID 無效而引發(fā) Null 指針異常的風(fēng)險(xiǎn)。此外,如果視圖僅出現(xiàn)在布局的某些配置中,則綁定類中包含其引用的字段會(huì)使用 @Nullable 標(biāo)記。
- 類型安全:每個(gè)綁定類中的字段均具有與它們在 XML 文件中引用的視圖相匹配的類型。這意味著不存在發(fā)生類轉(zhuǎn)換異常的風(fēng)險(xiǎn)。
這些差異意味著布局和代碼之間的不兼容將會(huì)導(dǎo)致構(gòu)建在編譯時(shí)(而非運(yùn)行時(shí))失敗。
與數(shù)據(jù)綁定的對比
視圖綁定和數(shù)據(jù)綁定均會(huì)生成可用于直接引用視圖的綁定類。但是,視圖綁定旨在處理更簡單的用例,與數(shù)據(jù)綁定相比,具有以下優(yōu)勢:
更快的編譯速度:視圖綁定不需要處理注釋,因此編譯時(shí)間更短。
易于使用:視圖綁定不需要特別標(biāo)記的 XML 布局文件,因此在應(yīng)用中采用速度更快。在模塊中啟用視圖綁定后,它會(huì)自動(dòng)應(yīng)用于該模塊的所有布局。
反過來,與數(shù)據(jù)綁定相比,視圖綁定也具有以下限制:
視圖綁定不支持布局變量或布局表達(dá)式,因此不能用于直接在 XML 布局文件中聲明動(dòng)態(tài)界面內(nèi)容。
視圖綁定不支持雙向數(shù)據(jù)綁定。
考慮到這些因素,在某些情況下,最好在項(xiàng)目中同時(shí)使用視圖綁定和數(shù)據(jù)綁定。您可以在需要高級功能的布局中使用數(shù)據(jù)綁定,而在不需要高級功能的布局中使用視圖綁定。
使用視圖綁定
添加元素到build.gradle
文件中
android {
...
viewBinding {
enabled = true
}
}
如果您希望在生成綁定類時(shí)忽略某個(gè)布局文件,請將 tools:viewBindingIgnore=“true” 屬性添加到相應(yīng)布局文件的根視圖中:
<LinearLayout ... tools:viewBindingIgnore="true" > ... </LinearLayout>
使用
模塊視圖綁定后,系統(tǒng)為XML布局文件生成綁定類 – 類名為XML文件名轉(zhuǎn)大駝峰, 末尾加Binding一詞
如result_profile.xml ==> 綁定類為ResultProfileBinding
<LinearLayout ... > <TextView android:id="@+id/name" /> <ImageView android:cropToPadding="true" /> <Button android:id="@+id/button" android:background="@drawable/rounded_button" /> </LinearLayout>
綁定類 ResultProfileBinding
具有字段:name
(TextView) 和 button
(Button)。 該布局沒有ImageView的ID,不存在對它的引用
每個(gè)綁定類有一個(gè)getRoot()
方法, 為相應(yīng)布局根視圖提供引用,如上綁定類的getRoot()
返回LinearLayout根視圖
在Activity中使用視圖綁定
如果需要設(shè)置綁定類實(shí)例在Activity中使用,需要在Activity的onCreate()中執(zhí)行:
(1). 調(diào)用生成綁定類中包含靜態(tài)inflate()方法, 會(huì)創(chuàng)建綁定類實(shí)例供Activity使用
(2). 通過getRoot()
方法或使用 Kotlin語法獲取根視圖
(3). 將根視圖傳遞到setContentView(), 使成為屏幕上的活動(dòng)視圖
private lateinit var binding: ResultProfileBinding override fun onCreate(savedInstanceState: Bundle) { super.onCreate(savedInstanceState) binding = ResultProfileBinding.inflate(layoutInflater) val view = binding.root setContentView(view) }
可以使用該綁定類的實(shí)例引用視圖
binding.name.text = viewModel.name binding.button.setOnClickListener { viewModel.userClicked() }
在Fragment中使用視圖綁定
在Fragment中的onCreateView()方法中執(zhí)行以下步驟
(1) 調(diào)用生成的綁定類包含的inflate()
方法, 此操作會(huì)創(chuàng)建綁定類實(shí)例供Fragment使用
(2) 調(diào)用getRoot()方法或 bingClass.root 獲取根視圖引用
(3) 從onCreateView()
方法返回根視圖,使其成為屏幕活動(dòng)視圖 inflate() 方法會(huì)要求您傳入布局膨脹器。如果布局已膨脹,您可以調(diào)用綁定類的靜態(tài) bind() 方法。
private var _binding: ResultProfileBinding? = null override fun onCreateView( inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle? ): View? { _binding = ResultProfileBinding.inflate(inflater, container, false) val view = bing.root return view } override fun on DestroyView() { super.onDestroyView() _binding = null }
binding.name.text = viewModel.name
到此這篇關(guān)于Android視圖綁定方法深入探究的文章就介紹到這了,更多相關(guān)Android視圖綁定內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于android實(shí)現(xiàn)五子棋開發(fā)
這篇文章主要為大家詳細(xì)介紹了基于android實(shí)現(xiàn)五子棋開發(fā),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02Android中判斷網(wǎng)絡(luò)連接是否可用的方法總結(jié)
這篇文章主要介紹了Android中判斷網(wǎng)絡(luò)連接是否可用的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-04-04Android編程實(shí)現(xiàn)自定義title功能示例
這篇文章主要介紹了Android編程實(shí)現(xiàn)自定義title功能,結(jié)合具體實(shí)例形式分析了Android自定義title的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-03-03自定義Toast工具類ToastUtil防止多次點(diǎn)擊時(shí)Toast不消失的方法
下面小編就為大家?guī)硪黄远xToast工具類ToastUtil防止多次點(diǎn)擊時(shí)Toast不消失的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04Android自定義View制作動(dòng)態(tài)炫酷按鈕實(shí)例解析
這篇文章主要為大家詳細(xì)解析了Android自定義View制作動(dòng)態(tài)炫酷按鈕實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07