当系统数据量很大时,前端的分页、异步获取方式就成了较好的解决方案。一直以来,我都希望使用自己开发的 jquery 插件做系统。

  现在,学习了 jquery 插件开发之后,渐渐地也自己去尝试着开发一些简单的插件,之前已经开发了手风琴、选项卡,今天和大家介绍一下这个 datatable 分页表格插件。

  我们先讲解使用,再分析插件的实现方式。

  手册地址:http://5ijy01.duapp.com/jq-ui/index.html?tab=tab12

1、引入jquery库和插件库、css文件

首先需要引入 jquery 库,因为我们的 datatable 插件依赖另外一个分页插件,所有需要先把这个分页插件库引入进来,最后再引入 datatable 插件的 js 和 css 文件

  1. <script type="text/javascript" src="js/jquery/jquery-1.7.2.min.js"></script>
  2.  
  3. <script type="text/javascript" src="js/pagination.js"></script>
  4. <link rel="stylesheet" href="css/blue/pagination.css"/>
  5.  
  6. <script type="text/javascript" src="js/datatable.js"></script>
  7. <link rel="stylesheet" href="css/blue/datatable.css"/>

2、插件使用

下面我们就介绍下插件如何使用。

首先,我们需要写一个 table 标签,其实,最主要的代码就只有第 5 行的 table 标签,前面的几个 button 是为了看插件交互的。

  1. <button class="default-button" onclick="update();">修 改</button>
  2. <button class="default-button" onclick="del();">删 除</button>
  3. <button class="default-button" onclick="reload();">刷 新</button>
  4.  
  5. <table id="first-datatable"></table>

然后,我们需要写一段 script 脚本来初始化 datatable 组件,以及加载首页数据。

  1. $("#first-datatable").datatable({
  2. width: "1000",
  3. height: "auto",
  4. columns: [
  5. { field: "id", columnName: "编号", css: { "text-align": "center" } },
  6. { field: "username", columnName: "用户名" },
  7. { field: "age", columnName: "年龄" },
  8. { field: "phone", columnName: "联系电话", css: { "text-align": "center" } },
  9. { field: "email", columnName: "邮箱" },
  10. { field: "description", columnName: "自我介绍" }
  11. ],
  12. url: "/jq-ui/ajax/admin_json.jsp",
  13. pageNum: 1, // 显示第几页数据,默认1
  14. pageSize: 15, // 每页数据数量,默认10
  15. pagination: true, // 是否启用分页组件,默认启用
  16. showCheckbox: true
  17. });

我们简单介绍一下参数:

  width:  是包裹 table 标签的 div 的宽度,您可以不设置这个参数的值,默认使用的 100% 即父元素的宽度

  height:     是包裹 table 标签的 div 的高度,默认 auto

  columns:  是一个 object[] 对象,定义 table 的列信息,包括列名、字段的 key、css样式

  url:           获取异步数据的远程地址

  pageNum:初始化时显示第几页数据

  pageSize:每页显示多少数据

  pagination:是否启用分页组件

  showCheckbox:是否显示行首的复选框,这个参数在需要进行数据选择时使用

后台代码就不在这个介绍了,如果需要可以去下载插件项目代码。后台返回一个 json 数据,应该包括最大页数、数据集合信息,如下:

  

现在,可以看到插件的效果了:

  

3、插件的实现方式和核心函数

插件初始化时首先生成 thead 和 表头,然后在 table 外面包裹一个 div , 然后通过参数配置的 url 参数获取数据,加载到 table 的 tbody 中。在这个过程中,会通过参数判断是否显示行首的复选框和分页组件。分页插件我们不做重点介绍,datatable 插件中的代码如下:

  1. if(options["pagination"]) {
  2. // 先把之前的分页组件删除
  3. $datatable.parent().find(".pagination").remove();
  4. // 定义一个div用于显示分页组件
  5. var $pagination = $("<div></div>").css("margin-top", "10px");
  6. // 初始化分页组件
  7. $pagination.pagination({
  8. pageNum: options["pageNum"],
  9. size: options["pageSize"],
  10. total: data["totalPage"],
  11. click: function(curr, s) {
  12. options["pageNum"] = curr;
  13. $.data(this, "datatable", options);
  14. loadData($datatable);
  15. return data["totalPage"];
  16. }
  17. });
  18. // 把分页组件追加到datatable组件
  19. $datatable.parent().append($pagination);
  20. }

为了方便用户获取数据、刷新表格,插件提供了两个函数:

  

4、刷新、获取

下面我们简单介绍下如何使用 reload 和 getSelectRows 函数

删除按钮的事件函数:

  1. /*
  2. * 删除函数
  3. */
  4. function del(tid) {
  5. var rows = $("#" + tid).datatable("getSelectRows");
  6. if(rows.length < 1) {
  7. alert("请至少选择一条数据");
  8. return;
  9. }
  10. var ids = new Array();
  11. for(var i = 0; i < rows.length; i++) {
  12. var id = rows[i]["id"];
  13. ids.push(id);
  14. }
  15. console.log(ids);
  16. $.ajax({
  17. type: "post",
  18. dataType: "json",
  19. data: { "ids": ids},
  20. traditional: true,
  21. url: "/jq-ui/ajax/admin_del.jsp",
  22. success: function(data) {
  23. if(data["retCode"] == '0') {
  24. alert("删除成功");
  25. $("#" + tid).datatable("reload");
  26. }
  27. }
  28. });
  29. }

更新按钮的事件函数类似,就不再重复介绍了。

刷新按钮的事件函数:

  1. /*
  2. * 点击"刷新"后调用datatable的reload函数重新加载数据
  3. */
  4. function reload(id) {
  5. $("#" + id).datatable("reload");
  6. }

5、项目地址

datatable.js http://5ijy01.duapp.com/jq-ui/js/datatable.js

datatable.css http://5ijy01.duapp.com/jq-ui/css/blue/datatable.css

演示项目在 http://5ijy01.duapp.com/jq-ui/index.html

github项目在 https://github.com/xuguofeng/jq-ui

使用jQuery开发datatable分页表格插件的更多相关文章

  1. 基于JQuery可拖动列表格插件DataTables的踩坑记

    前言 最近项目中在使用能够拖动列调整列位置顺序的表格插件---DataTables,这也是目前我找到的唯一一种存在有这种功能的插件. 在查找使用方法的过程中发现可用案例并不多,且大多言语不详.本文将全 ...

  2. JQuery中的DataTables表格插件

    一.DataTables表格插件的简介 DataTables是一个jQuery的表格插件.它具有以下特点: 自动分页处理 即时表格数据过滤 数据排序以及数据类型自动检测 自动处理列宽度 可通过CSS定 ...

  3. bootstrap 分页表格插件

    找了两个table的插件,一个是bootstrap table ,另一个是bootstrap-paginator 这里只介绍 bootstrap table 插件 使用及简单案例 文档介绍:http: ...

  4. jQuery ajax 实现分页 kkpager插件

    代码片段一: <!--分页组件 JS CSS 开始--> <!--分页组件 CSS--> <link type="text/css" href=&qu ...

  5. 使用jQuery开发messager消息框插件

    1.插件使用 首先引入jquery库,然后引入dialog.js.dialog.css.messager.js.messager.css,如下: <script type="text/ ...

  6. 一些基于jQuery开发的控件

    基于jQuery开发,非常简单的水平方向折叠控件.主页:http://letmehaveblog.blogspot.com/2007/10/haccordion-simple-horizontal-a ...

  7. Datatables快速入门开发--一款好用的JQuery表格插件

    博主是一个java后端程序员小白,前端技术会用但不精通,做后台的一些功能经常要涉及表格的展示,分页,搜索,排序等等一系列功能,在经历了一段时间的原始手段,开始接触并使用Datatables,一个jqu ...

  8. 001_ jQuery的表格插件dataTable详解

    一. 1.启用id为"datatable1"标签的html的表格jQuery库 $("#datatable1").dataTable( ) Reference: ...

  9. 前端开发:一个开源、简单易用的jQuery表格插件(DataTables)

    DataTables是一个基于jQuery库的开源(MIT协议)表格插件,支持添加.排序.分页.搜索.过滤等功能,使用简单.广受欢迎,能够与主流前端UI整合(如bootstrap.jQuery UI等 ...

随机推荐

  1. [内网渗透]Cobaltstrike指令大全

    0x01 安装 Cobaltstrike是需要java环境才能运行的 linux下终端运行: sudo apt-get install openjdk-8-jdk windows下: 百度一堆配置JA ...

  2. Sql注入基本思路

    Sql注入基本思路 利用mysql自己动手 登录 使用show databases;查看数据库,sql注入主要用到的是information_schema这个库(mysql中大小写不敏感) infor ...

  3. 如何使用git把本地代码上传(更新)到github上

    最近用到git和github记录一下 1.下载git并安装 到官网下载并安装就行了 *如果下载失败,或者太慢,可以复制链接到迅雷下载 2.上传 1.在github新建存储库 库名不能是中文 2.在需要 ...

  4. SpringMVC(上)

    一.SpringMVC简介 (1)springMVC概述 Spring MVC属于SpringFrameWork的后续产品,Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块. 使用 ...

  5. TICK/TIGK运维栈安装运行【上】

    TICK/TIGK运运维metrics栈包括 InfuluxDB:为时间序列数据专门定制的高性能数据存储.TSM引擎允许高速接收和数据压缩.完全go语言编写.编译成一个单一的二进制,没有外部依赖.简单 ...

  6. checkbox与label内的文字垂直居中的解决方案

    <label style="float:left;margin-top:5px;margin-left:10px;cursor:pointer"><input t ...

  7. 备份数据库的shell

    #!/bin/bash #定义备份数据库名 dbname=yourdbname #定义备份数据库的用户名和密码 dbuser=yourdbuser dbpasswd=yourdbpasswd #数据库 ...

  8. ISO/IEC 9899:2011 摘要

    本国际标准指定了C编程语言的形式并建立了对用它所表达的程序的解释.其目的在于促进在多种计算机系统上的C语言程序的可移植性.可靠性.可维护性以及高效的执行. 为了详细地说明C语言本身以及C语言执行库,包 ...

  9. LayaIDE 报typescript编译版本不一致的错

    LayaIDE 报typescript编译版本不一致的错 文件 -> 首选项->用户设置那里修改下 settings.json // 将设置放入此文件中以覆盖默认设置 { "ty ...

  10. LeetCode:四数之和【18】

    LeetCode:四数之和[18] 题目描述 给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c ...