衆所周知,Retrofit2+Rxjava2常用的請求格式如下:
//Api.getApiService()爲單例模式封裝的Retrofit.Builder().create(xxx.class)
Api.getApiService().login(map)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Observer<LoginBean>() {
@Override
public void onSubscribe(Disposable d) {
}
@Override
public void onNext(LoginBean value) {
}
@Override
public void onError(Throwable e) {
}
@Override
public void onComplete() {
}
});
有很多請求都沒有太多map、zip……的操作符。
常用的請求我們都是用上面這一個,然後其中onSubscribe和OnComplete也比較少會用到,每次這樣重複寫就會很難看。我們來把它稍作封裝。這些請求一般都是在P層做的,所以我們可以在P層的基類哪裏封裝,代碼如下:
/**
* 網絡請求的封裝
*/
protected <M> void request(Observable<M> api, OnRespListener<M> listener){
api.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Observer<M>() {
@Override
public void onSubscribe(Disposable d) {
}
@Override
public void onNext(M value) {
listener.onSuccess(value);
}
@Override
public void onError(Throwable e) {
listener.onFailed(e);
}
@Override
public void onComplete() {
}
});
}
public interface OnRespListener<M>{
void onSuccess(M value);
void onFailed(Throwable e);
}
ok,封裝完成,我們只要傳入Api.getApiService().login(map)這個東西還有實現響應接口就闊以了,例如:
request(Api.getApiService().login(map), new OnRespListener<LoginBean>() {
@Override
public void onSuccess(LoginBean value) {
if(value.getCode() == 200){
getV().loginSuccess(value);
}else{
getV().loginFail(value.getMsg());
}
}
@Override
public void onFailed(Throwable e) {
getV().onError(e);
}
});
前面的Api.getApiService().login(map)裏面是帶有實體Bean的,所以後面寫new OnRespListener的時候,Android studio會自動提示補全了這個LoginBean。
有冇感覺代碼瞬間變得很簡潔了。