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. Java基础教程——二维数组

    二维数组 Java里的二维数组其实是数组的数组,即每个数组元素都是一个数组. 每个数组的长度不要求一致,但最好一致. // 同样有两种风格的定义方法 int[][] _arr21_推荐 = { { 1 ...

  2. LeetCode 034 Search for a Range

    题目要求:Search for a Range Given a sorted array of integers, find the starting and ending position of a ...

  3. 【2020.11.30提高组模拟】剪辣椒(chilli)

    剪辣椒(chilli) 题目描述 在花园里劳累了一上午之后,你决定用自己种的干辣椒奖励自己. 你有n个辣椒,这些辣椒用n-1条绳子连接在一起,任意两个辣椒通过用若干个绳子相连,即形成一棵树. 你决定分 ...

  4. 【NOIP2015模拟11.2晚】JZOJ8月4日提高组T2 我的天

    [NOIP2015模拟11.2晚]JZOJ8月4日提高组T2 我的天 题目 很久很以前,有一个古老的村庄--xiba村,村子里生活着n+1个村民,但由于历届村长恐怖而且黑暗的魔法统治下,村民们各自过着 ...

  5. js实现视频截图,视频批量截图,canvas实现

    截取视频的某一时间的图像并保存 利用canvas的绘画能力画出视频某一帧的视频画面, 获得到图像之后转换成base64图像, 再利用a标签的实现自动保存到本地 html代码 <!DOCTYPE ...

  6. buuctf-web-[极客大挑战 2019]BuyFlag 1

    打开网页,然后发现menu中有个buyflag的连接,点进去 如果你想买这个flag ,你必须是来自CUIT的一名学生,还必须回答正确的密码.简单了解,我们查看源码,发现思路 POST方式传入两个参数 ...

  7. PyQt(Python+Qt)学习随笔:QTableView的showGrid属性

    老猿Python博文目录 老猿Python博客地址 showGrid属性用于控制视图中数据项之间是否显示网格,如果该属性为True,则绘制网格:如果该属性为False,则不绘制网格. showGrid ...

  8. [BJDCTF 2nd]duangShell

    [BJDCTF 2nd]duangShell 点击进去之后提示我们swp源代码泄露,访问http://xxx/.index.php.swp下载该文件 该文件产生的原因是:​使用vi编辑器打开文件时,会 ...

  9. PHP代码审计分段讲解(8)

    20 十六进制与数字比较 源代码为: <?php error_reporting(0); function noother_says_correct($temp) { $flag = 'flag ...

  10. LeetCode初级算法之数组:189 旋转数组

    旋转数组 题目地址:https://leetcode-cn.com/problems/rotate-array/ 给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数. 示例 1: 输 ...