解決android viewmodel 數(shù)據(jù)刷新異常的問題
3年的wpf開發(fā)經(jīng)驗(yàn),自認(rèn)為對數(shù)據(jù)驅(qū)動(dòng)UI開發(fā)模式的使用不是問題,但當(dāng)開始研究android的mvvm模式開發(fā)時(shí),發(fā)現(xiàn)兩年多的android開發(fā)經(jīng)驗(yàn)已經(jīng)將之前的wpf開發(fā)忘得7788了。感慨一下:人老了,記憶力就這么脆弱。
談?wù)}:adroid mvvm開發(fā)模式 之 viewmodel使用小麻煩。
viewmodel
public class MyViewModel extends ViewModel {
private MutableLiveData<List<User>> mUserList;
public MutableLiveData<List<User>> getUserList(){
if(mUserList == null){
return new MutableLiveData<List<User>>();
}
return mUserList
}
public void addContacts(List<User> list){
if(mUserList.getValue() == null){
mUserList.setValue(list);
}else{
mUserList.getValue().addAll(list);
mUserList.setValue(mUserList.getValue());
}
}
}
Activity
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
/* 注冊數(shù)據(jù)變更監(jiān)聽*/
model = ViewModelProviders.of(this).get(MyViewModel.class);
model.getUserList().observe(this, list -> {
Log.i(TAG, "getUserList size:" + list.size());
});
}
......
List<User> list = new ArrayList<User>();
...
/*更改綁定數(shù)據(jù)*/
model.addContacts(list);
以上是錯(cuò)誤簡寫代碼,讓我百撕不得姐??!
嘗試好多方法監(jiān)聽中的log始終不得見,最后一次嘗試將viewmodel中的List<>改成了Integer,直接在定義類型時(shí)初始化,發(fā)現(xiàn)好用。思量之后發(fā)現(xiàn)代碼中的神來之筆額
if(mUserList == null){
return new MutableLiveData<List<User>>();
}
return mUserList
兩個(gè)return 返回的不是一個(gè)對象! 無語,撕了大半天終得解!
補(bǔ)充知識(shí):使用Android DataBinding時(shí)發(fā)現(xiàn)只能顯示一次,不能動(dòng)態(tài)更新數(shù)據(jù)
本文只是記錄解決錯(cuò)誤的過程,可能起不到分享的意義。
剛開始使用 dagger2 + DataBinding 的結(jié)構(gòu),很多東西也不是很清晰。
現(xiàn)象
一個(gè)頁面有三塊布局,我使用一個(gè)Activity搭配三個(gè)Fragment實(shí)現(xiàn)。
通過三個(gè)Fragment共同使用Activity的ViewModel來實(shí)現(xiàn)數(shù)據(jù)共享。
但是最后出現(xiàn)個(gè)現(xiàn)象就是只有剛進(jìn)入頁面時(shí),ViewModel中的數(shù)據(jù)會(huì)顯示在視圖上。
通過點(diǎn)擊事件更新ViewModel中 ObservableField 對象中的數(shù)據(jù),并不會(huì)刷新視圖。

原因
千辛萬苦找到了是因?yàn)樵陧?xiàng)目中使用了 Dagger2
在給三個(gè)Fragment注入 Activity的 ViewModel 時(shí),實(shí)際上是注入了三個(gè) ViewModel 對象
導(dǎo)致每個(gè)Fragment的binding綁定的ViewModel都是不同的,自然不會(huì)有什么聯(lián)系
解決1
通過靜態(tài)代碼塊的方式實(shí)現(xiàn)了 ViewModel 的單例
在 module 中 @Provide修飾的方法中,返回的是單例模式的 ViewModel
解決2(失敗了)
在 Activity 的 module 中 @Provide修飾的方法上再加上個(gè) @Singleton
報(bào)錯(cuò):AppComponent has a @Singleton
原因:@Singleton 在 AppComponent 上聲明了,@Singleton 并不是設(shè)計(jì)模式中的單例模式,而是 Dagger2 為了保證 module 提供的產(chǎn)品,在一個(gè) Scope (Component)中,只有一個(gè)對象的標(biāo)簽。

如上,表示了三個(gè) Module 類在 AppComponent 這個(gè)scope中是單例的
解決3
既然外層已經(jīng)使用了 @Singleton ,那么我們可以自定義一個(gè)注解來表示一個(gè) scope
創(chuàng)建注解:@NewPesticideSingle (名字任意)
標(biāo)注在 Module 和對應(yīng)的 Component 中即可
以上這篇解決android viewmodel 數(shù)據(jù)刷新異常的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Android自定義ListView實(shí)現(xiàn)下拉刷新上拉加載更多
- android RecycleView實(shí)現(xiàn)下拉刷新和上拉加載
- Android巧用XListView實(shí)現(xiàn)萬能下拉刷新控件
- Android自定義view仿微信刷新旋轉(zhuǎn)小風(fēng)車
- Android自定義控件ListView下拉刷新的代碼
- Android ExpandableListView實(shí)現(xiàn)下拉刷新和加載更多效果
- Android RecyclerView的刷新分頁的實(shí)現(xiàn)
- android使用SwipeRefreshLayout實(shí)現(xiàn)ListView下拉刷新上拉加載
- android使用PullToRefresh框架實(shí)現(xiàn)ListView下拉刷新上拉加載更多
- Android 中RecyclerView頂部刷新實(shí)現(xiàn)詳解
- Android四種方式刷新View的操作方法
相關(guān)文章
Android實(shí)現(xiàn)動(dòng)態(tài)向Gallery中添加圖片及倒影與3D效果示例
這篇文章主要介紹了Android實(shí)現(xiàn)動(dòng)態(tài)向Gallery中添加圖片及倒影與3D效果的方法,涉及Android針對圖片的加載、顯示、翻轉(zhuǎn)、倒影等相關(guān)特效功能實(shí)現(xiàn)技巧2016-08-08
andriod開發(fā)之Activity的渲染機(jī)制
本文給大家分享的是在andriod開發(fā)中經(jīng)常需要用到的Activity的渲染機(jī)制的詳細(xì)說明,主要是通過實(shí)例給大家講解Activity是如何畫到屏幕上的,希望大家能夠喜歡2018-03-03
Flutter彈性布局Flex水平排列Row垂直排列Column使用示例
這篇文章主要為大家介紹了Flutter彈性布局Flex水平排列Row垂直排列Column使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
Android TextView使用SpannableString設(shè)置復(fù)合文本的方法詳解
這篇文章主要介紹了Android TextView使用SpannableString設(shè)置復(fù)合文本的方法,結(jié)合實(shí)例形式詳細(xì)分析了Android中SpannableString類的功能及相關(guān)用法,需要的朋友可以參考下2016-08-08
關(guān)于Android短信驗(yàn)證碼的獲取的示例
本篇文章主要介紹了關(guān)于Android短信驗(yàn)證碼的獲取的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
android實(shí)現(xiàn)圖片閃爍動(dòng)畫效果的兩種實(shí)現(xiàn)方式(實(shí)用性高)
本文通過兩種方法給大家講解了android實(shí)現(xiàn)圖片閃爍動(dòng)畫效果,實(shí)用性非常高,對這兩種方法感興趣的朋友一起通過本文學(xué)習(xí)吧2016-09-09

