我是一位对测试新技术感兴趣的android开发人员。 知道,我想使用架构组件来改善项目。
我想列出服务器上的文章,并在recyclerView中显示它们。 应该注意的是,我已经使用WebSocket与服务器通信。
我的例程如下:
首先,我从viewModel类中调用loadArticles方法:
BlogViewModel = ViewModelProvders.of(this).get(BlogViewModel.class);
viewModel.loadArticles();
BlogViewModel主体下方:
public class BlogViewModel extends ViewModel {
private BlogRepository repository;
private CompositeDisposable compositeDisposable = new CompositeDisposable();
public ObservableField<Boolean> isLoading = new ObservableField<>();
public MutableLiveData<List<Article>> articles = new MutableLiveData<>();
public BlogViewModel() {
this.repository = new BlogRepository();
}
public void loadArticles() {
isLoading.set(true);
compositeDisposable.add(repository
.getArticles()
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribeWith(new DisposableObserver<List<Article>>() {
@Override
public void onNext(List<Article> data) {
articles.setValue(data);
}
@Override
public void onError(Throwable e) {
// FIXME: 3/31/2019
}
@Override
public void onComplete() {
isLoading.set(false);
}
}));
}
@Override
protected void onCleared() {
super.onCleared();
if (!compositeDisposable.isDisposed()) {
compositeDisposable.dispose();
}
}
}
此外,BlogRepository类的定义如下:
public class BlogRepository {
private BlogRemoteDataSource remoteDataSource = BlogRemoteDataSource.getInstance();
public Observable<List<Article>> getArticles() {
if (Util.isConnect()) {
return remoteDataSource.getArticles();
} else {
return null;
}
}
}
BlogRemoteDataSource类的定义如下:
public class BlogRemoteDataSource {
private Application app = (Application) Application.getInstance();
private List<Article> articles;
public static BlogRemoteDataSource getInstance() {
return new BlogRemoteDataSource();
}
public Observable<List<Article>> getArticles() {
JSONObject objData = new JSONObject();
try {
objData.put("itemID", "");
} catch (JSONException e) {
e.printStackTrace();
}
app.getSocket().observe(app.getOwner(), socket -> socket.event(Api.EVENT_GET_ARTICLE)
.data(objData)
.setCallbacks(new SocketCallback() {
@Override
public void onSuccess(JSONObject data) {
try {
articles = Article.parse(data.getJSONArray(Constant.PARAM_BODY));
} catch (JSONException e) {
e.printStackTrace();
}
}
@Override
public void onError(int code, String message) {
}
}).send());
return Observable.just(articles);
}
}
我的问题是当我返回Observable.just(articles)作为输出时。执行完此行后,该类中的onNext方法将立即触发BlogViewModel,但是当从服务器获取文章列表和值时,不会触发onNext方法。
请指导我如何告诉ViewModel,数据已经准备好了?
谢谢。
答案 0 :(得分:0)
嗨,您可以使用observeForever而不是observe,因为observeForever()未绑定到任何LifecycleOwner。所以像下面这样使用它:
首先删除您的BlogRepository类,并将BlogViewModel更新为 下方:
public class BlogViewModel extends ViewModel {
private CompositeDisposable compositeDisposable = new CompositeDisposable();
private BlogRemoteDataSource remoteDataSource = BlogRemoteDataSource.getInstance();
public ObservableField<Boolean> isLoading = new ObservableField<>();
public BlogViewModel() {
this.repository = new BlogRepository();
}
public void loadArticles() {
isLoading.set(true);
remoteDataSource.getArticles();
}
@Override
protected void onCleared() {
super.onCleared();
if (!compositeDisposable.isDisposed()) {
compositeDisposable.dispose();
}
}
}
然后如下更新BlogRemoteDataSource:
public class BlogRemoteDataSource {
private Application app = (Application) Application.getInstance();
public MutableLiveData<List<Article>> articles = new MutableLiveData<>();
public static BlogRemoteDataSource getInstance() {
return new BlogRemoteDataSource();
}
public void getArticles() {
JSONObject objData = new JSONObject();
try {
objData.put("itemID", "");
} catch (JSONException e) {
e.printStackTrace();
}
app.getSocket().observeForever(app.getOwner(), socket -> socket.event(Api.EVENT_GET_ARTICLE)
.data(objData)
.setCallbacks(new SocketCallback() {
@Override
public void onSuccess(JSONObject data) {
try {
List<Article> newArticeList = Article.parse(data.getJSONArray(Constant.PARAM_BODY));
articles.postValue(newArticeList);
articles.notifyObserver();
} catch (JSONException e) {
e.printStackTrace();
}
}
@Override
public void onError(int code, String message) {
}
}).send());
}
}
希望现在有帮助!! :)