使用SmartRefreshLayout加载下一页数据后,页面滚动到最顶端问题解决问题

#####使用的版本’com.scwang.smartrefresh:SmartRefreshLayout:1.0.3’

          if (nowPage == 1) {
                mBeans.clear()
                mBeans.addAll(resDataS)
                refreshLayout.finishRefresh()
                refreshLayout.isLoadmoreFinished = false
            } else {
                mBeans.addAll(resDataS)
                refreshLayout.finishLoadmore()
                if (resDataS.size < 16) {
                    Toast.makeText(this, "数据全部加载完毕", Toast.LENGTH_SHORT).show()
                    refreshLayout.isLoadmoreFinished = true//将不会再次触发加载更多事件
                }
            }

######加载下一页数据后,页面跳动到最顶端问题解决:
######RecyclerView外面再包一层NestedScrollView解决,并且RecycleView中不能使用android:layout_marginTop=""标签

<include layout="@layout/base_appbar_layout" />

<com.scwang.smartrefresh.layout.SmartRefreshLayout
    android:id="@+id/refreshLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">

    <com.scwang.smartrefresh.layout.header.ClassicsHeader
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

    <androidx.core.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fillViewport="true">

        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/containe_rl"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"/>

    </androidx.core.widget.NestedScrollView>

    <com.scwang.smartrefresh.layout.footer.ClassicsFooter
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:srlClassicsSpinnerStyle="Translate" />
</com.scwang.smartrefresh.layout.SmartRefreshLayout>
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
SmartRefreshLayout 是一个用于 Android 的下拉刷新和上拉加载的框架,它本身并不处理 item 的点击事件,因此,你需要在 RecyclerView 的 Adapter 中处理 item 的点击事件。 下面是一个示例代码: ```java public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<Item> mData; public MyAdapter(List<Item> data) { mData = data; } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); ViewHolder holder = new ViewHolder(view); return holder; } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { Item item = mData.get(position); holder.mTextView.setText(item.getTitle()); // 设置 item 的点击事件 holder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理 item 的点击事件 Toast.makeText(holder.itemView.getContext(), "You clicked item " + position, Toast.LENGTH_SHORT).show(); } }); } @Override public int getItemCount() { return mData.size(); } static class ViewHolder extends RecyclerView.ViewHolder { TextView mTextView; public ViewHolder(@NonNull View itemView) { super(itemView); mTextView = itemView.findViewById(R.id.tv_title); } } } ``` 在上面的代码中,我们在 onBindViewHolder 方法中设置了 item 的点击事件,当用户点击某个 item 时,会弹出一个 Toast 提示用户点击了哪个 item。 你可以根据自己的需求来处理 item 的点击事件,例如跳转到详情页等。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值