ViewBinding的使用

2021-09-18  本文已影响0人  爱写代码的小王子

首先什么是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按钮。

上一篇下一篇

猜你喜欢

热点阅读