Datatables是一款jquery表格插件。它是一个高度灵活的工具,可以将任何HTML表格添加高级的交互功能。

  分页,即时搜索和排序

  几乎支持任何数据源:DOM, javascript, Ajax 和 服务器处理

  支持不同主题 DataTables, jQuery UI, Bootstrap, Foundation
  各式各样的扩展: Editor, TableTools, FixedColumns ……
  丰富多样的option和强大的API
  支持国际化
  超过2900+个单元测试
  免费开源 ( MIT license )! 商业支持
  更多特性请到官网查看
  http://www.datatables.club/
下面是使用dt构建数据源和绑定
  1.构建datatable数据源
 

table = $('#hjInfoTable').DataTable({ //构造函数
    "data": data,//数据源--参过datatable.js说明文档data,data传入就行
    "columns": [
    { "title": "<input align=\"center\" type=\"checkbox\" class=\"checkAll\" checked=\"checked\" id=\"checkAll\"/>" },
    { "title": "工程编号s" },
    { "title": "用户号" },
    { "title": "户名" },
    { "title": "地址" },
  ],
  "oLanguage": {
    "sLengthMenu": "每页显示 _MENU_ 条",
    "sProcessing": "<img src='" + imgUrl + "'/><span>&nbsp;&nbsp;Loading...</span>",
    "sInfo": "从 _START_ 到 _END_, 共 _TOTAL_ 条记录",
    "sInfoEmpty": "",
    "sGroupActions": "_TOTAL_ records selected: ",
    "sAjaxRequestGeneralError": "未能连接服务器,请重试!",
    "sEmptyTable": "未找到相关记录",
    "sZeroRecords": "共 0 条记录",
    "sInfoFiltered": "(从 _MAX_ 条数据中检索)",
    "oPaginate": {
    "sPrevious": "上一页",
    "sNext": "下一页",
    "sPage": "页",
    "sPageOf": "of"
  },
    "sSearch": "搜索",
  },
  "bFilter": false, //搜索栏
    "fnInitComplete": function (oSettings, json) { //datatables初始化完毕后回调方法

    .......里面可加回调事件

    },
  "fnCreatedRow": function (nRow, aData, iDataIndex) {
    $(nRow).css("cursor", "pointer");
  },
  "aoColumnDefs": [{
    "render": function (data, type) {
      return "<div align='center'><input type=\"checkbox\" checked=\"checked\" name=\"ckb-jobid\" value=" + data + "></div>";
    }, "aTargets": 0 //第一列
  }, { //隐藏业务类型列
    "targets": [5],
    "visible": false
  },
  { //隐藏划价人列
    "targets": [6],
    "visible": false
  }
  { //隐藏用户站点列
    "targets": [11],
    "visible": false
  }, ],

 });
}

1.全选或者全部不选
//使用live绑定数据,因为checkAll还没有加载好
$("#checkAll").die().live("click", function () {
    if (this.checked) {
    $(this).attr('checked', 'checked')
    $("input[name='ckb-jobid']").each(function () {
    this.checked = true;
  });

} else {
    $(this).removeAttr('checked')
    $("input[name='ckb-jobid']").each(function () {
    this.checked = false;
    });
  }
});

2.点击单个按钮

$("input[name='ckb-jobid']").die().live("click", function () {
  if ($(this).is(":checked") == false) {
    $("#checkAll").prop("checked", false);
  } else {
    var flag = true;
    $("#checkAll").prop("checked", true);
    $("input[name='ckb-jobid']").each(function () {
    if (this.checked == false) {
      $("#checkAll").prop("checked", false);
      flag = false;
      return;
    }
  });
}

});

(转载https://blog.csdn.net/younghaiqing/article/details/83010449)

DataTable添加checkbox实现表格数据全选,单选(点选)的更多相关文章

  1. easyui tree datagrid动态添加表头和表格数据,动态弹出框,修改和删除按钮

    1.要有获取表头的URL和表格的URL 背景:点击树的一个节点,就加载一个表格,这个表格是动态的,表头和表格数据都是动态的 解决方案:需要两个URL,一个是获取表头的URL,一个是获取表格数据的URL ...

  2. html 和 html5(一)(表格 | 列表 | 提交按钮 | 单选 |复选 | 框架 | 脚本 | html字符实体 )

    一.框架 使用iframe来显示目录链接页面 iframe可以显示一个目标链接的页面 目标链接的属性必须使用iframe的属性,如下实例: 实例 <iframe src="demo_i ...

  3. JSF dataTable 添加列 动态创建数据表 列

    @Named @ViewScoped public class LiveRangeService implements Serializable { private List< Map<S ...

  4. angular JS中使用jquery datatable添加checkbox点击事件

    'use strict'; app.controller('DataTableCtrl', function ($scope, $compile) { $scope.selected = []; $s ...

  5. elementUi使用dialog的进行信息的添加、删除表格数据时进行信息提示。删除或者添加成功的信息提示(SpringBoot+Vue+MybatisPlus)

    文章目录 1.添加新用户,通过dialog的弹窗形式 1.1 添加的按钮 1.2 调用方法设置窗口可见 1.3 窗口代码 1.4 提交注册信息方法 1.5 使用mybatisPlus方法进行添加信息到 ...

  6. bootstrap 列表 表格 表单 复选 单选 多选 输入框组

    一.列表 ul li 二.表格 table  (http://www.runoob.com/bootstrap/bootstrap-tables.html) 1. 基本表格 <table cla ...

  7. wpf中为DataGrid添加checkbox支持多选全选

    项目中用到DataGrid, 需要在第一列添加checkbox, 可以多选.全选. 其中涉及的概念DataTemplate, DataGridCellStyle, DataGridCellContro ...

  8. JQuery实现表格的全选和反选,以及分页勾选保存(laypage插件分页的使用)

    需求: 1.全选与取消全选 2.单个勾选,点击表格单元格中checkbox勾选,也可以在点击行勾选,便与用户操作 3.分页勾选保存 4.固定表头 功能一: 说明:操作全选按钮的同时,遍历每一个tr中的 ...

  9. DevExpress GridControl使用教程:之 添加 checkbox 复选框

    添加一列,FieldName为"FLAG",将ColumnEdit设置为复选框样式. gridview1   =>optionsbehavior =>  editabl ...

随机推荐

  1. 安装Linux软件时遇到这个问题,如何解决?

    提示 Could not get lock /var/lib/dpkg/lock 报错? 有些小伙伴在使用 apt 包管理器更新或安装软件时,可能会遇到过诸如以下的错误提示: E: Could not ...

  2. idea 安装教程

    臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭臭是猪臭 ...

  3. zk与eureka区别

    cap永远的神!

  4. Alpha冲刺——代码规范,冲刺计划

    这个作业属于哪个课程 https://edu.cnblogs.com/campus/fzzcxy/2018SE2/ 这个作业要求在哪里 https://edu.cnblogs.com/campus/f ...

  5. 跟我一起学Redis之Redis持久化必知必会

    前言 Redis是出了名的速度快,那是因为在内存中进行数据存储和操作:如果仅仅是在内存中进行数据存储,那就会导致以下问题: 数据随进程退出而消失:当服务器断电或Redis Server进程退出时,内存 ...

  6. 第2.2节 Python的语句

    上节已经介绍了极简的Python代码编写,已经用到了赋值语句,本节对Python的程序语句进行介绍. 一. 常用命令 在介绍Python语句之前,先介绍一下几个有用的Python命令. dir(模块名 ...

  7. 第1章 Python学习环境构建目录

    第1章 引子 第1.1节 学习环境搭建 第1.2节 Python学习环境的使用 第2章 Python编程基础知识 第2.1节 简单的Python数据类型.变量赋值及输入输出 第2.2节 Python的 ...

  8. 第15.20节 PyQt(Python+Qt)入门学习:QColumnView的作用及开发中对应Model的使用

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.概述 在Qt Designer的Item Views(Model-based)部件中,Colum ...

  9. 超详细讲解mysql存储过程中的in/out/inout

    存储过程 大概定义:用一个别名来描述多个sql语句的执行过程. 最简单 delimiter // create PROCEDURE p1() begin select * from userinfo; ...

  10. LoadRunner 多用户并发 登录,上传数据,登出的脚本教程

    这里记录 Web/Http  模式,模拟多用户并发进行  : 登录,上传数据,退出登录一整套流程.并发的用户量多少,可自定义.这里不介绍录屏的方式,是自己写脚本去执行的. 1.安装loadRunner ...