初探ViewBinding

视图访问的方式有常用的findViewById,ButterKnife等多种方式,这些方式的各方面对比如下

如上图所示,在简明、编译安全和编译速度上都各有优势,那么有没有一种方式可以一石 "三" 鸟呢。谷歌在Android Studio 3.6 Canary 11版本中正式推出视图绑定(View Binding),来看下使用方法,

首先需要使用AS 3.6 Canary 11之上的版本,这里我们使用AS 3.6 Beta 1(也可以使用最新的AS 4.0 Canary 01),升级gradle plugin版本到3.6.0 beta01

buildscript {
    ……
    dependencies {
        classpath "com.android.tools.build:gradle:3.6.0-beta01"
    }
}

然后在app中开启viewbinding

apply plugin: 'com.android.application'

android {
    ……
    defaultConfig {
        ……

        viewBinding {
            enabled = true
        }
    }
    ……
}

接下来新建一个布局文件activity_view_binding,内容如下

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.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/text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        tools:text="111" />

    <android.support.v7.widget.AppCompatImageView
        android:id="@+id/image"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_margin="10dp"
        app:layout_constraintDimensionRatio="1:1"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@id/text"
        app:layout_constraintWidth_percent="0.4" />
</android.support.constraint.ConstraintLayout>

然后在Activity等需要使用布局的类中进行ViewBinding的初始化及使用,如下

public class ViewBindingActivity extends AppCompatActivity {
    private ActivityViewBindingBinding viewBinding;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        viewBinding = ActivityViewBindingBinding.inflate(LayoutInflater.from(this));
        setContentView(viewBinding.getRoot());
        viewBinding.text.setText("view binding");
        viewBinding.image.setImageResource(R.color.black);
    }
}

ViewBinding的初始化有三种方式,

inflate(@NonNull LayoutInflater inflater);
inflate(@NonNull LayoutInflater inflater, @Nullable ViewGroup parent, boolean attachToParent);
bind(@NonNull View rootView);

ViewBinding不用再手动进行类型转换,也避免了空指针错误。如果不想生成ViewBinding,可以在布局的根视图上使用tools:viewBindingIgnore="true"。

当然ViewBinding现在还是测试阶段,也有很多问题,例如tools:viewBindingIgnore有时会无效;如果你的布局名称比较长的时候,生成的ViewBinding类也比较长,没有自定义生成ViewBinding类名称的方式;视图id比较长的时候,生成的对象名称也比较长。

在Butterknife的github主页上也有这样一段话,

扫描二维码关注公众号,回复: 9457419 查看本文章
Attention: Development on this tool is winding down. Please consider switching to view binding in the coming months.

看来JakeWharton还是比较推荐自家的ViewBinding,大家可以开始尝试使用,如果有问题可以进行反馈,相信ViewBinding也会越来越强大。

发布了53 篇原创文章 · 获赞 17 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/jklwan/article/details/102767871