Android数据双向绑定原理实现和应用场景

 更新时间:2023年04月26日 11:22:33   作者:顽石九变  
本文介绍了Android数据双向绑定的原理和实现方式,包括基于观察者模式和数据绑定框架的实现方法,以及应用场景和优缺点的分析,帮助开发者了解和应用数据双向绑定技术,提升应用的交互性和响应速度

安卓的数据双向绑定类似Vue这种前端框架,只要修改模型的数据,页面上显示的数据也会跟着变化,不需要取出控件来赋值。

一、使用databinding类

修改配置文件build.gradle,增加配置项

android {
    ...
    buildFeatures {
        viewBinding true
    }
}

修改Activity类获取binding属性

public class MainActivity extends AppCompatActivity {
    ActivityMainBinding binding;
    private ProgressDialog pg;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        binding = ActivityMainBinding.inflate(getLayoutInflater());
        setContentView(binding.getRoot());
    }
}

接下来就可以使用binding获取页面的元素了,页面的控件就是binding的一个属性,不再需要使用findViewById方法取得控件。

比如:

binding.imageview
binding.btn

二、双向绑定

1、增加绑定配置

修改配置文件build.gradle,增加两个配置项

android {
    ...
    defaultConfig {
        ...
        dataBinding {
            enabled true
        }
    }
    ...
    buildFeatures {
        viewBinding true
    }
}

2、修改布局文件(activity_main.xml),增加一层layout

格式如下:

根节点是

节点声明了需要绑定的变量

@{user.text}:在页面上显示模型属性

@={user.text}:双向绑定,修改控件的值后,同步修改模型属性值

<?xml version="1.0" encoding="utf-8"?>
<layout 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">
    <data>
        <variable
            name="user"
            type="com.nbmt.cash.BindingEntity" />
    </data>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context=".MainActivity">
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="30sp"
            android:id="@+id/textView"
            android:text="@{user.text}"
            android:background="@color/purple_200"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent" />
        <EditText
            android:id="@+id/edit_text"
            android:layout_width="wrap_content"
            android:layout_marginTop="20dp"
            android:textSize="30sp"
            android:layout_height="wrap_content"
            android:text="@={user.text}"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/textView" />
    </LinearLayout>
</layout>

3、在Activity中使用

1)创建模型对象,必须继承基类androidx.databinding.BaseObservable

  • @Bindable:声明该属性可以用于绑定
  • 修改setXX方法,调佣notifyPropertyChanged(BR.text)发送修改通知;也可以调用notifyChange()通知所有属性
import androidx.databinding.BaseObservable;
import androidx.databinding.Bindable;
    public class BindingEntity extends BaseObservable {
    private String text;
    public BindingEntity(String text) {
        this.text = text;
    }
    @Bindable
    public String getText() {
        return text;
    }
    public void setText(String text) {
        this.text = text;
        notifyPropertyChanged(BR.text);
    }
}

2)修改Activity,使用binding对象

  • ActivityMainBinding是框架自动生成的,和MainActivity对应
  • 使用DataBindingUtil.setContentView(this, R.layout.activity_main)获取绑定对象
  • 去掉setContentView(R.layout.activity_main)
public class MainActivity extends AppCompatActivity {
    private ActivityMainBinding binding;
    private BindingEntity entity;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
        //setContentView(R.layout.activity_main);
        entity = new BindingEntity("我是测试数据");
        binding.setUser(entity);
    }
}

后续只要修改entity的属性值,页面控件就会自动跟着变化

到此这篇关于Android数据双向绑定原理实现和应用场景的文章就介绍到这了,更多相关Android数据双向绑定内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解android 用webview加载网页(https和http)

    详解android 用webview加载网页(https和http)

    这篇文章主要介绍了详解android 用webview加载网页(https和http),详细的介绍了两个错误的解决方法,有兴趣的可以了解一下
    2017-11-11
  • 捕获与解析Android NativeCrash

    捕获与解析Android NativeCrash

    Android 开发中,NE一直是不可忽略却又异常难解的一个问题,原因是这里面涉及到了跨端开发和分析,需要同时熟悉 Java,C&C++,并且需要熟悉 NDK开发,并且解决起来不像 Java异常那么明了,本文为了解决部分疑惑,将从NE的捕获,解析与还原等三个方面进行探索
    2021-06-06
  • Android View类与SurfaceView类详解

    Android View类与SurfaceView类详解

    本文主要介绍Android View类与SurfaceView类,这里提供了详细的Android View类和SurfaceView类的使用方法,有兴趣的小伙伴可以参考下
    2016-08-08
  • Qt5.12.6配置Android Arm开发环境(图文)

    Qt5.12.6配置Android Arm开发环境(图文)

    本文主要介绍了Qt5.12.6配置Android Arm开发环境,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • android studio更新gradle错误构建项目失败的解决方法

    android studio更新gradle错误构建项目失败的解决方法

    这篇文章主要介绍了android studio更新gradle错误构建项目失败的解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • Android 如何收集已发布程序的崩溃信息

    Android 如何收集已发布程序的崩溃信息

    下面我就说说如何收集程序运行过程的异常信息。需要的朋友可以过来参考下
    2013-07-07
  • Android基于hover组件实现监控鼠标移动事件的方法

    Android基于hover组件实现监控鼠标移动事件的方法

    这篇文章主要介绍了Android基于hover组件实现监控鼠标移动事件的方法,结合实例形式分析了hover组件监控鼠标光标在view上变化的操作技巧,需要的朋友可以参考下
    2017-02-02
  • Android WebView 优化之路

    Android WebView 优化之路

    Android WebView 优化之路,如何才能更有效的对Android WebView进行优化,本文将为大家一一举例,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • Android实现断点续传功能

    Android实现断点续传功能

    这篇文章主要为大家详细介绍了Android实现断点续传功能,能在上次的断点处继续上传,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • 朋友圈实现图片+文字转发功能(必看篇)

    朋友圈实现图片+文字转发功能(必看篇)

    下面小编就为大家带来一篇朋友圈实现图片+文字转发功能(必看篇)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03

最新评论