ViewBinding(1) — 在Activity中使用

前言

Android开发过程中,我们经常要做的就是初始化控件,最原始的方式是findViewById,后面又出现了Butternikef,接着是kotlin推出的kotlin-android-extensions插件,可惜的是kotlin-android-extensions插件已经废弃,官方提倡用ViewBinding代替。那么今天就来讲讲ViewBinding的使用。
今天涉及内容:

  1. ViewBinding是啥
  2. ViewBinding使用配置
  3. ViewBindingActivity中使用
  4. ViewBinding使用注意及忽略

一. ViewBinding 是啥

ViewBinding简单来说就是实现控件初始化的插件,起到视图绑定作用,代替繁琐的findViewById来初始化控件的框架。

二. ViewBinding 使用配置

在使用ViewBinding之前,你需要在app_module对应的build.gradle中添加如下配置:

android {
   
    buildFeatures{
        viewBinding true
    }
    
    //其他代码省略
    //......
}

三. ViewBinding 在 Activity 中使用

为了后面描述方便,下面先给出MainActivity对应的布局文件activity_main.xml代码:

<?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"
    tools:context=".ui.MainActivity">

    <TextView
        android:id="@+id/tv_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.08" />

    <Button
        android:id="@+id/btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="30dp"
        android:text="点击"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.498"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tv_name" />

</androidx.constraintlayout.widget.ConstraintLayout>

以前我们是这样在MainActivity中加载布局和初始化控件的:

class MainActivity : AppCompatActivity(), View.OnClickListener {

    private lateinit var mTvName: TextView
    private lateinit var mBtn: Button

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        initData()
        setListener()
    }

    private var initData = {
        mTvName = findViewById(R.id.tv_name)
        mBtn = findViewById(R.id.btn)

        mTvName.text = "我是神"

    }

    private var setListener = {
        mBtn.setOnClickListener(this)
    }

    override fun onClick(v: View) {
        when (v.id) {
            R.id.btn -> {
                LogUtil.i("====我点击了=====")
            }
            else -> {}
        }
    }

}

在使用ViewBinding以后,我们是这样在MainActivity中初始化控件的:

还有 42% 的精彩内容
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
支付 ¥2.00 继续阅读

推荐阅读更多精彩内容