網站首頁 編程語言 正文
視圖綁定
用于替代findViewById的方式獲取id元素, google推薦使用
原理
啟用視圖綁定之后,系統會為該模塊中的每個 XML 布局文件生成一個綁定類。綁定類的實例包含對在相應布局中具有 ID 的所有視圖的直接引用。
優點(相比于findViewById)
- Null 安全:由于視圖綁定會創建對視圖的直接引用,因此不存在因視圖 ID 無效而引發 Null 指針異常的風險。此外,如果視圖僅出現在布局的某些配置中,則綁定類中包含其引用的字段會使用 @Nullable 標記。
- 類型安全:每個綁定類中的字段均具有與它們在 XML 文件中引用的視圖相匹配的類型。這意味著不存在發生類轉換異常的風險。
這些差異意味著布局和代碼之間的不兼容將會導致構建在編譯時(而非運行時)失敗。
與數據綁定的對比
視圖綁定和數據綁定均會生成可用于直接引用視圖的綁定類。但是,視圖綁定旨在處理更簡單的用例,與數據綁定相比,具有以下優勢:
更快的編譯速度:視圖綁定不需要處理注釋,因此編譯時間更短。
易于使用:視圖綁定不需要特別標記的 XML 布局文件,因此在應用中采用速度更快。在模塊中啟用視圖綁定后,它會自動應用于該模塊的所有布局。
反過來,與數據綁定相比,視圖綁定也具有以下限制:
視圖綁定不支持布局變量或布局表達式,因此不能用于直接在 XML 布局文件中聲明動態界面內容。
視圖綁定不支持雙向數據綁定。
考慮到這些因素,在某些情況下,最好在項目中同時使用視圖綁定和數據綁定。您可以在需要高級功能的布局中使用數據綁定,而在不需要高級功能的布局中使用視圖綁定。
使用視圖綁定
添加元素到build.gradle
文件中
android {
? ? ...
? ? viewBinding {
? ? ? ? enabled = true
? ? }
}
如果您希望在生成綁定類時忽略某個布局文件,請將 tools:viewBindingIgnore=“true” 屬性添加到相應布局文件的根視圖中:
<LinearLayout ... tools:viewBindingIgnore="true" > ... </LinearLayout>
使用
模塊視圖綁定后,系統為XML布局文件生成綁定類 – 類名為XML文件名轉大駝峰, 末尾加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,不存在對它的引用
每個綁定類有一個getRoot()
方法, 為相應布局根視圖提供引用,如上綁定類的getRoot()
返回LinearLayout根視圖
在Activity中使用視圖綁定
如果需要設置綁定類實例在Activity中使用,需要在Activity的onCreate()中執行:
(1). 調用生成綁定類中包含靜態inflate()方法, 會創建綁定類實例供Activity使用
(2). 通過getRoot()
方法或使用 Kotlin語法獲取根視圖
(3). 將根視圖傳遞到setContentView(), 使成為屏幕上的活動視圖
private lateinit var binding: ResultProfileBinding override fun onCreate(savedInstanceState: Bundle) { super.onCreate(savedInstanceState) binding = ResultProfileBinding.inflate(layoutInflater) val view = binding.root setContentView(view) }
可以使用該綁定類的實例引用視圖
binding.name.text = viewModel.name binding.button.setOnClickListener { viewModel.userClicked() }
在Fragment中使用視圖綁定
在Fragment中的onCreateView()方法中執行以下步驟
(1) 調用生成的綁定類包含的inflate()
方法, 此操作會創建綁定類實例供Fragment使用
(2) 調用getRoot()方法或 bingClass.root 獲取根視圖引用
(3) 從onCreateView()
方法返回根視圖,使其成為屏幕活動視圖 inflate() 方法會要求您傳入布局膨脹器。如果布局已膨脹,您可以調用綁定類的靜態 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
原文鏈接:https://blog.csdn.net/change_fate/article/details/127967347
相關推薦
- 2024-07-13 根據腳手架archetype快速構建spring boot/cloud項目
- 2022-11-01 python?類對象的析構釋放代碼演示_python
- 2022-12-26 python畫圖時linestyle,color和loc參數的設置方式_python
- 2022-09-09 使用Dockerfile腳本定制鏡像的方法_docker
- 2022-12-12 flutter?Bloc?更新后事件同步與異步詳解_Android
- 2022-07-24 基于Flutter實現多邊形和多角星組件_Android
- 2022-02-21 C語言圣誕樹的實現示例_C 語言
- 2022-09-15 .Net站點設置多個路由對應同一個Action_實用技巧
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支