viewBinding的作用
启用视图绑定之后,系统会为每个xml生成一个绑定类,我们在使用控件的时候就可以不用findviewbyid这种方式了,可以一定程度避免空指针。视图绑定主要用来替换findViewById。
启用视图绑定
视图绑定可以按模块启用,在需要绑定视图的模块的build.gradle中加入以下代码,启用viewbinding
viewBinding{
enabled=true
}
同步之后会为每个布局文件生成一个binding文件,每个绑定均包含对根视图以及具有ID的所有视图的引用。
Activity中使用视图绑定
class MainActivity : AppCompatActivity() {
private var mainBinding:ActivityMainBinding ? = null
override fun onCreate(savedInstanceState: Bundle?) {
//使用viewbinding替换原来的R.layout.activity_main
mainBinding = ActivityMainBinding.inflate(LayoutInflater.from(this))
// mainBinding!!.root获取根视图,对应Java的getRoot()方法
setContentView(mainBinding!!.root)
//直接使用mainBinding为控件赋值,无需使用findviewbyid
mainBinding!!.tvTest.text = "一个textview"
}
}
Fragment中使用视图绑定
class ViewBindingFragment : Fragment() {
private var ktbinding : KtLayoutFragmentBinding? = null
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
ktbinding = KtLayoutFragmentBinding.inflate(inflater)
// ktbinding!!.root获取根视图,对应Java的getRoot()方法
return ktbinding!!.root
}
override fun onDestroyView() {
super.onDestroyView()
ktbinding = null
}
}
与findViewByid()相比
视图绑定与传统的findViewById()相比有以下有点
- 空安全,视图绑定会创建对视图的直接引用,不会出现以前由于ID不存在导致的空指针异常,如果视图仅出现在布局的某些配置中,则绑定类中包含其引用的字段会使用 @Nullable 标记。
- 类型安全 每个绑定类中的字段在视图中都存在一个与之匹配的类型,因此不会出现类型转换错误。