react中遇到的分页问题

问题:

1.使用useState时不能够进行当前页码的改变,数据不会随着页码变化

2.删除当前页的最后一条数据时,页码返回上一页但是数据为空

解决:

1.由于useState和useRef的区别那我们就不考虑使用useState

2.再删除的逻辑当中添加判断条件

javascript 复制代码
import React, { useRef } from 'react';
import { Pagination } from 'antd';

const YourComponent = () => {
  const currentPageRef = useRef(1); // 使用 useRef 来保存当前页码 可以为空
  const handlePageChange = (page) => {
    console.log(page, 'pageeeee');
    getMessage(page);
    currentPageRef.current = page; // 更新当前页码
  };

  const handleDelete = (id) => {
    // 执行删除操作
    // 删除成功后,判断当前页是否还有数据
    // 如果没有数据且不是第一页,则回退到上一页
    if (data.length === 1 && currentPageRef.current > 1) {
      const newPage = currentPageRef.current - 1; // 计算上一页的页码
      getMessage(newPage); // 获取上一页的数据
      currentPageRef.current = newPage; // 更新当前页码为上一页
    } else {
      getMessage(currentPageRef.current); // 否则重新请求当前页的数据
    }
  };

  return (
    <div>
      {/* 省略其他内容 */}
      <Pagination
        onChange={handlePageChange}
        current={currentPageRef.current}
        // 其他配置项...
      />
    </div>
  );
};

export default YourComponent;

补充:

react中useState、useRef之间的区别

  • useState:
javascript 复制代码
const [state, setState] = useState(0)
const fn = () => {
	setState(1)
	console.log(state) //输出0
}

组件更新不会 改变之前的状态,可以保存状态。

值变化,会render,视图会更新。

setState是异步的,同一个函数内设置的,不能实时获取到最新的值。

  • useRef:
javascript 复制代码
const num = useRef(0)
const fn = () => {
	num.current = 1
	console.log(num.current) //输出1
}

组件更新不会 改变之前的状态,可以保存状态。

值变化,不会render,视图不会更新。

设置的值是同步的,同一个函数内设置的,能实时获取到最新的值。

相关推荐
Asize15 分钟前
HTML5 Canvas 基础:从按帧动画到 ECharts 数据可视化
前端·javascript·canvas
默_笙18 分钟前
🎄 后端给我一堆扁平数据,我 10 行代码把它变成了树
前端·javascript
Mahut20 分钟前
我用 Electron + FFmpeg 做了一个本地视频处理工作站 ClipForge
前端·ffmpeg·electron
前端Hardy24 分钟前
又一个 AI 神器火了!
前端·javascript·后端
锋行天下28 分钟前
我试图优化 Vite 的拆包,结果首屏慢了 10 倍
前端·vue.js·架构
PBitW1 小时前
GPT训练我的第二天,我表示不过如此!!!😕😕😕
前端·javascript·面试
用户99045017780091 小时前
学习了AI修图,我把自己闲鱼出租房照片整成airbnb风格了
前端
kyriewen2 小时前
白宫直接给 OpenAI 下了限制令,GPT-5.6 不能随便放出来了
前端·javascript·面试
PedroQue993 小时前
Vite插件v0.2.6:架构优化与自动化升级
前端·vite
threerocks4 小时前
什么?我连 A2A、MCP 都没学会,现在又来了 AG-UI、A2UI.
前端·aigc·ai编程