JavaScript分页核心是数据切片、状态控制与视图更新,分为纯前端静态分页、懒加载式分页、带搜索的动态分页和服务端分页四类,适用场景依数据规模与后端支持而定。
用 JavaScript 实现分页功能,核心是“数据切片 + 状态控制 + 视图更新”,不依赖后端时重点在前端数据分块和用户交互逻辑。下面几种常见思路,按适用场景和复杂度排列:
把一整组数据按每页条数(如 10 条)切成多个子数组,用一个 currentPage 变量记录当前页码,每次切换就取对应页的数据渲染。
rentPage - 1) * pageSize, currentPage * pageSize)
适用于长列表、不想一次性拉太多数据的场景。监听滚动位置,当接近底部时触发加载,把新数据追加到现有列表末尾,并更新页码状态。
用户输入关键词或选择筛选条件后,先对原始数据做过滤,再重新分页。关键点是:分页状态(当前页码)要在过滤后重置为第 1 页,否则可能跳到空页。
前端只传页码和每页数量(如 page=3&limit=20),由后端返回该页数据 + 总条数。前端据此算出总页数并渲染分页控件。
基本上就这些。选哪种取决于数据规模、用户体验要求和后端支持程度。小项目用静态分页够用;真实业务系统优先和服务端分页配合;滚动加载适合内容流类页面。不复杂但容易忽略细节,比如页码越界、状态同步、加载反馈——补上这些,分页就稳了。