0

0

如何在 DataTables 中正确设置每页显示 5 行数据

心靈之曲

心靈之曲

发布时间:2026-01-13 11:53:20

|

260人浏览过

|

来源于php中文网

原创

如何在 DataTables 中正确设置每页显示 5 行数据

本文详解在使用 datatables(尤其是服务端分页模式)时,为何 `pagelength: 5` 失效,并提供可立即生效的配置方案,包括关键参数组合、常见陷阱及完整可运行示例。

在 DataTables 中,设置每页显示行数看似简单(如 pageLength: 5),但在 服务端分页(serverSide: true) 场景下,若后端未同步响应分页参数,前端配置将无法生效——这正是你遇到“仍显示 14 行而非 5 行”的根本原因。

SuperCms在线订餐系统
SuperCms在线订餐系统

模板采用响应式设计,自动适应手机,电脑及平板显示;满足单一店铺外卖需求。功能:1.菜单分类管理2.菜品管理:菜品增加,删除,修改3.订单管理4.友情链接管理5.数据库备份6.文章模块:如:促销活动,帮助中心7.单页模块:如:企业信息,关于我们更强大的功能在开发中……安装方法:上传到网站根目录,运行http://www.***.com/install 自动

下载

✅ 正确配置要点(服务端分页必备)

  1. pageLength 必须显式声明(推荐带引号写法 "pageLength": 5,兼容性更佳);
  2. paging: true 必须启用(即使 serverSide: true 默认开启,显式声明可避免某些版本兼容问题);
  3. lengthMenu 应为一维数组或标准二维数组
    • ✅ 推荐简洁写法:"lengthMenu": [5, 10, 20](隐藏“全部”选项,避免干扰);
    • ⚠️ 避免混用字符串与数字(如 ['Todos'])导致解析异常;
  4. 后端必须接收并应用 start 和 length 参数
    DataTables 在服务端模式下会自动在 AJAX 请求中携带 start(起始偏移)和 length(每页数量)字段(例如 ?start=0&length=5)。你的后端 API 必须据此截取数据并返回对应数量结果,否则前端无论怎么配都无效。

? 修正后的完整代码(已验证可用)

var select_server_table = $("#select_server_table_example").DataTable({
    processing: true,
    serverSide: true,
    paging: true,              // ✅ 关键:显式启用分页
    pageLength: 5,             // ✅ 每页默认显示 5 行
    lengthMenu: [5, 10, 20],  // ✅ 简洁一维菜单,避免字符串歧义

    ajax: {
        url: "http://192.168.03.30:8000/api/ipc/all",
        type: "GET",
        headers: {
            Authorization: "Bearer " + getToken,
        },
        data: function(d) {
            // ✅ DataTables 自动注入 start/length,无需手动拼接
            d.search = d.search?.value || ''; // 安全取值
            return d; // 直接返回对象,避免 JSON.stringify 导致参数丢失
        },
        dataSrc: function (response) {
            console.log("Backend response:", response);
            return response.ipcs || [];
        }
    },

    columns: [
        { data: "device_id", title: "Device ID" },
        { data: "name", title: "Name" },
        { data: "group", title: "Group" }
    ],

    error: function(xhr, error, thrown) {
        console.error("DataTables AJAX Error:", thrown);
    }
});

⚠️ 常见错误排查清单

  • ❌ 错误:data: function(d) { return JSON.stringify(d); }
    → 后果:AJAX 请求体变为字符串,后端无法解析 start/length,导致忽略分页逻辑。
    ✅ 正确:直接 return d;,让 DataTables 自动序列化为查询参数。

  • ❌ 错误:后端未读取 length 参数,始终返回全部 14 条数据。
    → 验证方法:在浏览器 Network 面板中检查请求 URL 是否含 &length=5,再确认后端是否据此限制 SQL LIMIT 或数组切片。

  • ❌ 错误:lengthChange: false 禁用了长度选择器,但未配合 pageLength 强制初始值 → 可能继承旧状态。
    ✅ 建议:保留 lengthChange: true(方便调试),上线前设为 false 并确保 pageLength 明确。

? 总结

Datatables 的 pageLength 不是“前端展示上限”,而是向后端发起的分页指令。在 serverSide: true 下,它的生效链条是:
前端配置 pageLength → DataTables 发送 length=N 参数 → 后端严格按此截取数据 → 前端渲染 N 行
任一环节断裂(尤其后端未实现),都将导致“配置失效”。务必前后端协同验证,方能稳定实现每页 5 行的目标。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

414

2024.04.29

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号