赞
踩
Android 中的 ViewBinding 是Android 的 Jetpack 的一部分。这个框架为的是让大家不用再写出特别多的 findViewById 代码找寻控件。如果使用这个框架,那么框架会为每个xml布局生成一个绑定类。绑定类的实例包含对在相应布局中具有 ID 的所有视图的直接引用。
当然在官方文档中有一句这个话:
In most cases, view binding replaces findViewById.
(在大多数情况下,视图绑定会替代 findViewById。)
这里介绍一下,因为 ViewBing 是新出来的原因,所以往往会有些不稳定,出现某些不知道的问题,所以我还是告诫大家:这个毕竟是新的技术,所以在工作中还是不要上手了,在平时的Demo 中可以使用它。
ViewBinding 对于 studio 和 gradle 都有限制。都规定需要使用 3.6.0 以上的版本。
首先如果需要使用 架构组件,那么大家需要在 project 的build.gradle 中有 google()。(当然这个是在创建应用的时候就会默认有的。)
repositories {
google()
jcenter()
}
如果使用 ViewBinding,需要在 Module 的 build.gradle 中添加如下:
android {
viewBinding {
enabled = true
}
}
或者是
android {
viewBinding.enabled = true
}
ViewBinding 在大家设置完之后就可以正式的使用了。
比如应用会默认生成一个 MainActivity 和一个 activity_main.xml 布局。那么大家就可以在代码中如此使用:
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val mBinding = ActivityMainBinding.inflate(layoutInflater)
setContentView(mBinding.root)
}
}
这里解释一下,它会将 XML 文件的名称转换为驼峰式大小写,并在末尾添加“Binding”一词。
如果有一个布局内容如下 :
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/textView" ... /> <Button android:id="@+id/button" ... /> <ImageView android:id="@+id/imageView" ... /> </androidx.constraintlayout.widget.ConstraintLayout>
这里大家可以看到,这个布局整体是一个 玉树布局,内部有三个控件 TextView ,Button ,ImageView 。他们有着自己各自的id,如果我们想在代码中进行使用,那么我们可以通过之前的 mBinding.控件找到自己所需要控件/.
如果不想让xml 文件生成Binding ,那么大家可以在根布局中添加 tools:viewBindingIgnore=“true” 忽略布局。
与使用 findViewById 相比,视图绑定具有一些很显著的优点:
视图绑定和数据绑定库均会生成可用于直接引用视图的绑定类。不过,这两者之间存在明显差异:
在官方文档中给出如此的建议:
如果使用的是简单的布局(和数据交互少的布局),那么推荐使用 ViewBinding。
如果使用的是复杂的布局(和数据交互多的布局),那么推荐使用 DataBinding。
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。