Datatable的分页入门

2024-05-16 16:18
文章标签 入门 分页 datatable

本文主要是介绍Datatable的分页入门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

源码请见1.Datatable的分页入门

一、 目标

使用mybatis获取数据库中的数据,使用datatable对页面进行分页展示。

二、 使用到的资源
  1. datatable的资源包(如我用的DataTables-1.10.15.zip)。(下载地址datatable中文地址 OR datatable offical site)
三、 项目结构

这里写图片描述
webapp下的extensions和media目录是拷贝的datatables资源中的2个目录。

四、 项目部分代码说明
4.1 使用README.sql创建数据库
#create a database
create database UserCenter;
#create a table
use UserCenter;
create table user(id int primary key auto_increment,name varchar(50),passwd varchar(50),age int
);
#add much data
insert into user(name,passwd,age) value('hash','1234',21);
insert into user(name,passwd,age) value('maven','1234',11);
insert into user(name,passwd,age) value('memorylorry','1234',22);
insert into user(name,passwd,age) value('lucy','1234',41);
insert into user(name,passwd,age) value('duck','1234',11);
insert into user(name,passwd,age) value('salary','1234',13);
insert into user(name,passwd,age) value('monkey','1234',51);
insert into user(name,passwd,age) value('dog','1234',22);
insert into user(name,passwd,age) value('march','1234',51);
insert into user(name,passwd,age) value('benz','1234',21);
insert into user(name,passwd,age) value('cookie','1234',12);
insert into user(name,passwd,age) value('fun','1234',55);
4.2 前台要装载datatable

通过columns数组选择要加载的列名;通过设置processing、serverSide、ajax三个参数加载数据。

$('#example').DataTable({columns : [ {"sWidth" : "100px",bSearchable : false,bSortable : false,data : 'id'}, {"sWidth" : "100px",bSearchable : true,bSortable : false,data : 'name'}, {"sWidth" : "100px",bSearchable : false,bSortable : false,data : 'passwd'}, {"sWidth" : "100px",bSearchable : false,bSortable : false,data : 'age'} ],"processing" : true,"serverSide" : true,"ajax" : "../getUserContentByMyself"});

这个ajax提出的请求时,会使用GET方式向服务器发送一些参数,如下所示,尤其是两个加黑的参数,表示页索引和页大小:

http://localhost:8080/DatatableTest/getUserContentByMyself
?draw=1&columns[0][data]=id&columns[0][name]=&columns[0][searchable]=false
&columns[0][orderable]=false&columns[0][search][value]=&columns[0][search][regex]=false
&columns[1][data]=name&columns[1][name]=&columns[1][searchable]=true
&columns[1][orderable]=false&columns[1][search][value]=&columns[1][search][regex]=false
&columns[2][data]=passwd&columns[2][name]=&columns[2][searchable]=false
&columns[2][orderable]=false&columns[2][search][value]=&columns[2][search][regex]=false
&columns[3][data]=age&columns[3][name]=&columns[3][searchable]=false
&columns[3][orderable]=false&columns[3][search][value]=&columns[3][search][regex]=false
&order[0][column]=0&order[0][dir]=asc&start=0&length=10&search[value]=
&search[regex]=false&_=1497077565075

4.3 后台获取数据

控制器要做这些事:

@Controller
public class GetUserByMyself {@Autowired@Qualifier("getUserPaginationService")private GetUserPaginationService getUserPaginationService;// 返回列表的内容@RequestMapping("getUserContentByMyself")@ResponseBodypublic Object getUserContent(HttpServletRequest request) {//获取页索引和页大小int start = Integer.parseInt(request.getParameter("start"));int len = Integer.parseInt(request.getParameter("length"));Map<String, String> params = new HashMap<String, String>();//根据页索引和页大小查询数据Map<String, Object> result = getUserPaginationService.getDetails(params, start, len);//返回数据return JSONArray.toJSON(result);}
}

DAO的实现方法:

public class GetUserPaginationDAO extends SqlSessionDaoSupport {// 获取分页的总数public Integer getUserSize(Map<String, String> params) {String statementCount = "cn.dectfix.dto.UserMapper.getUserSize";Integer totalSize = this.getSqlSession().selectOne(statementCount,params);if (totalSize != null)return totalSize;return 0;}// 获取分页的内容public Map<String, Object> getUserContent(Integer totalSize,Map<String, String> params,Integer skipResults, Integer rows) {Map<String, Object> resMap = new HashMap<String, Object>();String statementDetail = "cn.dectfix.dto.UserMapper.getUserContent";//装入要返回前台datatables的参数resMap.put("data",this.getSqlSession().selectList(statementDetail, params, new RowBounds(skipResults, rows)));resMap.put("recordsTotal", totalSize);resMap.put("recordsFiltered", totalSize);return resMap;}}

代码中通过selectList(statement,params,RowBounds)进行限定数据库查询的范围;
为了满足datatables控件的需求,需要向前台返回data、recordsFiltered、recordsTotal等参数。为什么呢?可以查看datatable实例返回ajax请求的内容格式,它也是带有这些参数的!

4.4 总结

这样就完成了基础的datatables的初始化,可能你还需要修改语言风格,搜索框的功能,或则是列排序的功能等,可以留意留意官网的做法。

这篇关于Datatable的分页入门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/995382

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

mybatis-plus分页无效问题解决

《mybatis-plus分页无效问题解决》本文主要介绍了mybatis-plus分页无效问题解决,原因是配置分页插件的版本问题,旧版本和新版本的MyBatis-Plus需要不同的分页配置,感兴趣的可... 昨天在做一www.chinasem.cn个新项目使用myBATis-plus分页一直失败,后来经过多方

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP

一文教你使用Python实现本地分页

《一文教你使用Python实现本地分页》这篇文章主要为大家详细介绍了Python如何实现本地分页的算法,主要针对二级数据结构,文中的示例代码简洁易懂,有需要的小伙伴可以了解下... 在项目开发的过程中,遇到分页的第一页就展示大量的数据,导致前端列表加载展示的速度慢,所以需要在本地加入分页处理,把所有数据先放

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联