最近有这样一个需求 由于页面是一个左右切换的tab栏 然后列表写在了fragment中,通过列表adapter跳转详情之后,需在详情中网络请求成功后通知列表刷新UI,通知数据刷新这种第一想法就是startActivtiyForResult。
先说一下遇到的一些问题:
1.点击事件重复编写,导致数据无法返回成功,直接响应列表页面的resultCode(也就是同一个控件被我写了两次点击事件)
2.通过startActivtiyForResult这种方法,列表收不到requestCode,导致页面无法刷新
由于上述都是小编自己遇到的一些问题 踩得坑 入坑的代码就不贴出来了 但如果你也有同样情况 可以检查一下 是不是写的和小编一样 点击事件重复 ;数据携带失败
UI大概是这样的:
因为有个左右滑动的tab栏 所以之后的列表都是fragment中处理的
实现方式如下:
页面1整体是一个Activity,但由于是左右滑动的tab栏,所以可以拆分为两个fragment。之后的逻辑就都在fragment中处理了。
回到最开始的问题,就是如何让详情返回后通知到列表页让他刷新数据呢?
如下:
首先 ,我们在adapter中写一个接口回调和一个事件监听,这个目的是让列表和详情页建立联系 当详情数据请求接口成功并退出页面时可以通知列表页面去刷新。
如下写法:
step 1
//--------------------------------这是adapter
private TestItemOnClickListener mListener = null;
/**
* 回调监听提供给Fragment
*
* @param listener
*/
public void testItemOnClickListener(TestItemOnClickListener listener) {
mListener = listener;
}
/**
* 接口回调
*/
public interface TestItemOnClickListener {
void onListener(TrainBean.ListBean listBean);
}
//--------------------------adapter中点击列表项时
/**
* 点击列表后的监听事件
*/
holder.itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mListener != null) {
mListener.onListener(listBean);
}
}
});
adapter代码就这些了 下面我们看fragment中的相关写法
step 2
//-----------------------------------这是fragment
//在recyclerView.setAdapter()之后去调用adapter中写好的接口回调 如下
testAdapter.testItemOnClickListener(new TrainAdapter.TrainItemOnClickListener() {
@Override
public void onListener(TrainBean.ListBean listBean) {
//点击列表跳转详情页面
Intent intent = new Intent(mContext, TestDetailActivity.class);
intent.putExtra("trainId", listBean.getId());//这里是你项目需要携带的一些数据可以忽略
intent.putExtra("fileId", listBean.getFileId());
//在详情页点击返回的时候要把新增的时间通知给列表UI 让其刷新 所以这里用startActivityForResult
startActivityForResult(intent,2021);//2021是请求的状态码 你可以定义到自己的工具类中 保证不重复即可
}
});
//----------------------------------还要有这样一个关键的方法
/**
*
*拿到详情数据的结果后列表进行刷新
* @param requestCode 请求状态码
* @param resultCode 响应码
* @param data
*/
@Override
public void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == 2021&& resultCode == RESULT_OK) {//RESULT_OK需要在详情设置 也就是下一步
Log.e("请求结果", "requestCode" + requestCode);
refresh();
}
}
下面我们看一下详情中的代码 这里面就比较简单 只需在接口请求成功的方法中将resultCode给它设置上
step 3
//--------------------------------这是detail详情页面
@Override
public voidtestSuccess() {//这是你接口请求成功的那个方法
setResult(RESULT_OK);
Log.e("返回结果", "RESULT_OK" + RESULT_OK);//这是测试过程中输出的日志
finish();
}
详情这里主要就是请求成功把resultCode返回 之后关闭页面
整体就是这样 这就实现了详情页面请求成功之后把结果通知到列表页 然后让列表去自动刷新UI,可以拿到最新的数据。
至于刷新UI的一些操作 大家可以去sou割一波哈 或者用自己常用的刷新方法即可~
网友评论