Android數(shù)據(jù)雙向綁定原理實現(xiàn)和應用場景
安卓的數(shù)據(jù)雙向綁定類似Vue這種前端框架,只要修改模型的數(shù)據(jù),頁面上顯示的數(shù)據(jù)也會跟著變化,不需要取出控件來賦值。
一、使用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
格式如下:
根節(jié)點是
節(jié)點聲明了需要綁定的變量
@{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)創(chuàng)建模型對象,必須繼承基類androidx.databinding.BaseObservable
- @Bindable:聲明該屬性可以用于綁定
- 修改setXX方法,調傭
notifyPropertyChanged(BR.text)發(fā)送修改通知;也可以調用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("我是測試數(shù)據(jù)");
binding.setUser(entity);
}
}
后續(xù)只要修改entity的屬性值,頁面控件就會自動跟著變化
到此這篇關于Android數(shù)據(jù)雙向綁定原理實現(xiàn)和應用場景的文章就介紹到這了,更多相關Android數(shù)據(jù)雙向綁定內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Android 中對JSON數(shù)據(jù)解析實例代碼
這篇文章主要介紹了Android 中對JSON數(shù)據(jù)解析實例代碼的相關資料,需要的朋友可以參考下2017-03-03
Android實戰(zhàn)教程第十篇仿騰訊手機助手小火箭發(fā)射效果
這篇文章主要為大家詳細介紹了Android實戰(zhàn)教程第十篇仿騰訊手機助手小火箭發(fā)射效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11
Android開發(fā)筆記之:在ImageView上繪制圓環(huán)的實現(xiàn)方法
本篇文章是對Android中在ImageView上繪制圓環(huán)的方法進行了詳細的分析介紹,需要的朋友參考下2013-05-05
Android Studio真機無線連接USB設備調試運行詳解流程
你在Android Studio寫app時是否也有想過如果可以不用數(shù)據(jù)線連接手機調試運行就好了?如果需要取出數(shù)據(jù)線插接的話我肯定是嫌麻煩的,但是模擬器有時候需要測試一些需要硬件支持的功能時又不管用,所以最好的測試還是在真機上,本篇教你扔掉數(shù)據(jù)線來無線調試2021-11-11

