Fragment页面涉及到状态变更时,需要重新加载数据进行刷新。项目中采用接收到EventBus刷新通知直接刷新页面,发现有时候界面内容没有刷新过来。
解放法案:需要采用延时刷新方案。
Fragment不可见时,可能导致页面刷新不成功问题。采用onResume生命周期中刷新界面最好。
1)接收到刷新通知以后,设置需要刷新的标记;
2)在onResume声明周期中,如果需要刷新,重新加载数据进行页面刷新;并且重置刷新标记,
防止页面每次进入出现重复刷新。
* 书城分类页面
*
* @author 周荣华
* @time 18-11-6 下午2:53
*/
public class BookCityClassifyFragment<S> extends Fragment {
/**
* 列表刷新标记
*/
private boolean isNeedUpdateList;
/**
* 重新回到页面
*
* @author zhouronghua
* @time 2019-11-04 20:33
*/
@Override
public void onResume() {
super.onResume();
if (isNeedUpdateList) {
// 重置恢复页面刷新标记
isNeedUpdateList = false;
// 重新加载列表数据
initData();
}
}
/**
* 用户登录成功和登出事件
* 说明: 刷新列表
*
* @param event : Event事件
* @author zhouronghua
* @time 2019-10-29 15:48
*/
@Subscriber(tag = MessageEventBusTag.TAG_LOGIN_AND_LOGOUT)
public void onEventLoginAndLogout(LoginAndLogoutEvent event) {
// 刷新页面数据
isNeedUpdateList = true;
}
/**
* 购买成功事件
*
* @param payResult : 购买成功状态 1: 成功 0: 失败
* @author zhouronghua
* @time 2019-10-29 16:46
*/
@Subscriber(tag = ShoppingConstant.PayState)
public void onEventMainThread(int payResult) {
// 是否购买成功
if (ShoppingConstant.PAY_SUCESS == payResult) {
// 支付成功刷新当前列表页面
isNeedUpdateList = true;
}
}
}
这样既可以提高刷新效率,又可以避免页面刷新失效问题。