首先什么是View Binding?
官方解释是:视图绑定是一项功能,可让您更轻松地编写与视图交互的代码。在模块中启用视图绑定后,它会为该模块中存在的每个 XML 布局文件生成一个 绑定类。绑定类的实例包含对在相应布局中具有 ID 的所有视图的直接引用。在大多数情况下,视图绑定会替换findViewById.
也就是说view binding能够给每一个布局绑定一个布局类,这样我们就不需要使用findViewById来获取对应的视图了,可以防止一些视图为空的情况导致的错误。
那么如何使用呢?
首先在build.gradle中添加以下代码,Kotlin语言
buildFeatures {
viewBinding = true
}
假设你的布局样式如下
<LinearLayout ... >
<TextView android:id="@+id/name" />
<ImageView android:cropToPadding="true" />
<Button android:id="@+id/button"
android:background="@drawable/rounded_button" />
</LinearLayout>
然后在你需要调用布局控件的地方,也就是布局对应的Activity中的onCreate方法中获取binding,得到root视图,也就是你布局中显示的内容
private lateinit var binding: ResultProfileBinding
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding = ResultProfileBinding.inflate(layoutInflater)
val view = binding.root
setContentView(view)
}
这里需要注意binding中不保存没有设置id的引用,也就是没有保存ImageView的引用,如果在布局中设置了id的控件,可以使用binding.id来调用对应的视图,例如binding.name来调用上面的TextView以及binding.button来调用Button按钮。