JQuery实现表格的全选和反选,以及分页勾选保存(laypage插件分页的使用)
需求:
1、全选与取消全选
2、单个勾选,点击表格单元格中checkbox勾选,也可以在点击行勾选,便与用户操作
3、分页勾选保存
4、固定表头
功能一:
说明:操作全选按钮的同时,遍历每一个tr中的checkbox,如果是全选的并且之前没有被选中的就勾选上,如果是取消取消就全部取消勾选
//全选与取消全选
$("#grid").on("click",'.checkAll',function(){
var me=this;//留住this
$("#grid tr+>td").find("input[type=checkbox]").each(function(i,e){
var id=$(e).attr("data-id")
if(me.checked){
//判断之前是否选中
if(idArr.indexOf(id)==-1){
$(e).prop("checked", true);
$(e).parent().parent().css("background-color","rgb(220, 248, 168)")
//将idObj中的添加属性
idArr.push(id)
}
}else{
$(e).prop("checked", false);
//在数组中找到
idArr.splice(idArr.indexOf(id),1);
$(e).parent().parent().css("background-color","")
}
})
})
功能二:
这个功能实现起来有些陷阱;
1、选中之前一定要做判断,不能重复的数组中push值
2、注意解决事件的冒泡问题,因为在勾选到checbox的时候同时会冒泡到tr上触发事件,所以加上了e.stopPropagation();,还有一个行内中一个a链接跳转,点击的时候也会触发,也需要阻止a标记的冒泡事件,对于a标记的事件冒泡本来用了
return false 应该可以解决,但是在实际情况并没有得到解决,(后来发现了原因是因为a标记里面的方法有一个跳转事件,跳转了return false就无效了)所以用了事件,在a标记的父元素的td中添加了一个事件,然后return false 完美解决了问题
//每一个checkBox的点击事件
$("#grid").on("click",'input[type=checkbox]:not(.checkAll)',function(e){
e.stopPropagation();//此处很重要,否则会冒泡触发其他事件
var id=$(this).attr("data-id")
if(this.checked){
//判断是否已经选中过
if(idArr.indexOf(id)==-1){
idArr.push(id);
$(this).parent().parent().css("background-color","rgb(220, 248, 168)")
}
}else{
idArr.splice(idArr.indexOf(id),1);
$(this).parent().parent().css("background-color","")
}
opCheckArr();
})
//为了用户更好的体验在tr上面也绑定事件
$("#grid").on("click",'tr:not(.tbl-header)',function(){
var id=$(this).attr("data-id");
var $chk=$(this).find("input[type=checkbox]");
//如果是勾选的那么久取消勾选,反之
if($chk[0].checked){
$chk.prop("checked", false);
$(this).css("background-color","");
idArr.splice(idArr.indexOf(id),1);
}else{
//判断是否之前有选中过,如果选中了就不在执行
if(idArr.indexOf(id)==-1){
//将行中的checkbox选中
$chk.prop("checked", true);
idArr.push(id);
$(this).css("background-color","rgb(220, 248, 168)")
}
}
})
//为了阻止a标记的事件冒泡,否则会冒泡到tr上面
$("#grid").on("click",'td:last-child',function(){
return false;
})
/*
*检查操作全选的checkbox
*/
function opCheckArr(){
if(idArr.length==pageSize){
$("#grid").find('.checkAll').prop("checked",true);
$('.table-fixed').find('.checkAll').prop("checked",true);//克隆的checkbox也需要勾选上
}else{
$('#grid').find('.checkAll').prop("checked",false);
$('.table-fixed').find('.checkAll').prop("checked",false);//克隆的checkbox也需要取消勾选
}
}
功能三:
实现过程:
勾选的时候操作数组idArr 勾选的时候push;
取消勾选的时候需要找到相应位置的元素将其删除 splice;
全选的时候,遍历一下一个每一个tr中的checkbox,之前要判断,如果勾选了就不要在操作数组
功能在功能一、二中已经实现了
如果不需要功能三,只需要在构建表格的时候将idArr数组清空即可
功能四:表头固定
实现过程:滚动div的时候,在现有的表格前面创建一个表格,内容为克隆原表格的表头,设置宽度
陷阱:克隆的表头出来之后还需要给其绑定事件,在这里用了深克隆其实是没有用的,因为原来的事件是代理在表格上面而不是在tr上面
解决:在克隆的checkbox点击的时候trigger一下原表格的click事件,还是有克隆表格的表头不能隐藏,只能删除和添加
js
$(".scroll-tabel").on('scroll',function(){
//判断是否有表头table在
var el=$(this).find('.table-fixed');
if(!el[0]){
$(this).append("<table class='table-fixed conTbl' style='position:absolute;top:0;font-size:13px;table-layout:fixed;'></table>");
//在原始表格找找到表头项进行克隆
var $thead=$("#tbl").find('tr.tbl-header').clone(true);
var older=$(this).find(".tbl-header").children();
//设置固定表头的宽度
$thead.children().each(function(idx,ele){
$(ele).css("width",older.eq(idx).css("width"));
$(ele).css("height",older.eq(idx).css("height"));
})
$(this).find('.table-fixed').append($thead);
//为克隆的checkbox绑定事件
$thead.on('click','.checkAll',function(){
$("#grid").find('.checkAll').trigger("click");
})
}else{
//就设置top值
el.css("top",$(this)[0].scrollTop+"px");
if(parseFloat(el.css("top"))==0){
el.remove();//这个必须要删除不能隐藏否则会导致复制出来的全选问题
}
}
})
完整页面代码
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>账单管理</title>
<link href="../lib/ligerUI/skins/Green/css/ligerui-all.css" rel="stylesheet" type="text/css" />
<link href="css/main.css" rel="stylesheet"/>
<link href="css/table.css" rel="stylesheet"/>
<script src="../lib/jquery/jquery-1.9.0.min.js" type="text/javascript"></script>
<script src="../lib/ligerUI/js/core/base.js" type="text/javascript"></script>
<script src="../lib/ligerUI/js/plugins/ligerLayout.js" type="text/javascript"></script>
<script src="../lib/ligerUI/js/plugins/ligerTree.js" type="text/javascript"></script>
<script src="../lib/ligerUI/js/plugins/ligerGrid.js" type="text/javascript"></script>
<script src="../lib/ligerUI/js/plugins/ligerDialog.js" type="text/javascript"></script>
<script src="../lib/ligerUI/js/plugins/ligerCheckBox.js" type="text/javascript"></script>
<script src="../lib/ligerUI/js/plugins/ligerComboBox.js" type="text/javascript"></script>
<script src="../lib/My97DatePicker/WdatePicker.js" type="text/javascript"></script>
<script src="../js/laypage/laypage.js" type="text/javascript"></script>
<script src="js/public.js"></script>
<script src="js/pubScroll.js" type="text/javascript"></script>
<style>
.conTbl th{min-width: 100px;}
a{
cursor: pointer;
color:blue;
}
#tbl{
width:1405px;
height:624px;
overflow: auto;
}
.conTbl th,.conTbl td{white-space: nowrap}
.conTbl th:nth-child(2){
min-width:30px;
}
</style>
</head>
<body>
<table class="banner">
<tr>
<td>开始日期:</td><td class="padr20"><input type="text" id="fromDate" class="Wdate item-text green-ipt" onfocus="WdatePicker({dateFmt:'yyyy-MM'})"></td>
<td>结束日期:</td><td class="padr20"><input type="text" id="toDate" class="Wdate item-text green-ipt" onfocus="WdatePicker({dateFmt:'yyyy-MM'})"></td>
<td>所在区域:</td><td class="padr20"><input type="text" id="area"></td>
<td>是否收费:</td><td class="padr20"><input type="text" id="isfree"></td>
<!-- <td>系统类型:</td><td class="padr20"><input type="text" id="system"></td> -->
<td><input type="text" class="green-ipt" id="searchVal" placeholder="输入用户名字搜索"> </td><td><button class="green-btn" id="search">搜索</button></td>
</tr>
</table>
<div class="btns"><button id="export" class="green-btn">导出已勾选</button></div>
<div id="tbl" class="scroll-tabel" style="position:relative">
<table id="grid" class='conTbl' style="font-size: 13px;table-layout:fixed"></table>
</div>
<div id="page"></div>
<div id="no">暂无数据</div>
<script type="text/javascript">
var g,freeData;
var pageNo = 1;
var pageSize = 100;
var win1;
var idOjbBuc={},idObj={};
var idArr=[];
$(function (){
initLoad();
initEvent();
scrollEvent();
});
function scrollEvent(){
$(".scroll-tabel").on('scroll',function(){
//判断是否有表头table在
var el=$(this).find('.table-fixed');
if(!el[0]){
$(this).append("<table class='table-fixed conTbl' style='position:absolute;top:0;font-size:13px;table-layout:fixed;'></table>");
//在原始表格找找到表头项进行克隆
var $thead=$("#tbl").find('tr.tbl-header').clone(true);
var older=$(this).find(".tbl-header").children();
//设置固定表头的宽度
$thead.children().each(function(idx,ele){
$(ele).css("width",older.eq(idx).css("width"));
$(ele).css("height",older.eq(idx).css("height"));
})
$(this).find('.table-fixed').append($thead);
//为克隆的checkbox绑定事件
$thead.on('click','.checkAll',function(){
$("#grid").find('.checkAll').trigger("click");
})
}else{
//就设置top值
el.css("top",$(this)[0].scrollTop+"px");
if(parseFloat(el.css("top"))==0){
el.remove();//这个必须要删除不能隐藏否则会导致复制出来的全选问题
}
}
})
}
function initEvent(){
//搜索
$("#search").click(function(){
searchCilck();
});
//导出
$("#export").click(function(){
if(idArr==undefined||idArr.length==0){
$.ligerDialog.warn("没有选择账单,请选择账单!");
return;
}
var str=idArr.join(";");
window.location.href = '../exportexcel_exportBathBillMs?ids='+str;
})
//设置全选
$("#grid").on("click",'.checkAll',function(){
var me=this;
$("#grid tr+>td").find("input[type=checkbox]").each(function(i,e){
var id=$(e).attr("data-id")
if(me.checked){
//判断之前是否选中
if(idArr.indexOf(id)==-1){
$(e).prop("checked", true);
$(e).parent().parent().css("background-color","rgb(220, 248, 168)")
//将idObj中的添加属性
idArr.push(id)
}
}else{
$(e).prop("checked", false);
//在数组中找到
idArr.splice(idArr.indexOf(id),1);
$(e).parent().parent().css("background-color","")
}
})
})
//每一个checkBox的点击事件
$("#grid").on("click",'input[type=checkbox]:not(.checkAll)',function(e){
e.stopPropagation();//此处很重要,否则会冒泡触发其他事件
var id=$(this).attr("data-id")
if(this.checked){
//判断是否已经选中过
if(idArr.indexOf(id)==-1){
idArr.push(id);
$(this).parent().parent().css("background-color","rgb(220, 248, 168)")
}
}else{
idArr.splice(idArr.indexOf(id),1);
$(this).parent().parent().css("background-color","")
}
opCheckArr();//判断全选的checkbox是否需要勾选上
})
//为了用户更好的体验在tr上面也绑定事件
$("#grid").on("click",'tr:not(.tbl-header)',function(){
var id=$(this).attr("data-id");
var $chk=$(this).find("input[type=checkbox]");
//如果是勾选的那么久取消勾选,反之
if($chk[0].checked){
$chk.prop("checked", false);
$(this).css("background-color","");
idArr.splice(idArr.indexOf(id),1);
}else{
//判断是否之前有选中过,如果选中了就不在执行
if(idArr.indexOf(id)==-1){
//将行中的checkbox选中
$chk.prop("checked", true);
idArr.push(id);
$(this).css("background-color","rgb(220, 248, 168)")
}
}
})
//为了阻止a标记的事件冒泡,否则会冒泡到tr上面
$("#grid").on("click",'td:last-child',function(){
return false;
})
}
/*
*检查操作全选的checkbox
*/
function opCheckArr(){
if(idArr.length==pageSize){
$("#grid").find('.checkAll').prop("checked",true);
$('.table-fixed').find('.checkAll').prop("checked",true);//克隆的checkbox也需要勾选上
}else{
$('#grid').find('.checkAll').prop("checked",false);
$('.table-fixed').find('.checkAll').prop("checked",false);//克隆的checkbox也需要取消勾选
}
}
function initLoad() {
//转化日期比当前小一个月
var yearM = getPrevMonth();
$("#fromDate").val(yearM);
$("#toDate").val(new Date().Format("yyyy-MM"));
$.when(getAreaData(),getDBSourcesList()).done(function(data,data1) {
//初始化所在区域
$("#area").ligerComboBox({
selectBoxHeight: 200,
tree:{
idFieldName: 'treeCode',
parentIDFieldName: 'treePCode',
textFieldName :'name',
checkbox: false,
data: data
},
onSelected: function (id) {
$("#area").data("data-id", id);
}
})
yearM = yearM.replace('-','');
queryData();
//startQueryData('','','',yearM,yearM,data1[0].id,pageNo,pageSize,1); //1代表查询全部 2查询差额
})
freeData = [
{ text: '是', id: '0' },
{ text: '否', id: '1' }
];
$("#isfree").ligerComboBox({
data: freeData,
onSelected: function (id) {
$("#isfree").data("data-id", id);
}
})
}
function startQueryData(userName,org_code,isNo,fromYearMonth,toYearMonth,system,pageNo,pageSize,flag){
if((parseInt(toYearMonth.substring(0,4),10)*12+parseInt(toYearMonth.substring(4),10))-(parseInt(fromYearMonth.substring(0,4),10)*12+parseInt(fromYearMonth.substring(4),10))>2){
$.ligerDialog.warn("查询日期范围不能超过三个月");
return;
}else{
$.ligerDialog.waitting('正在统计收费情况,请耐心等候(<span>30</span>)...');
window.timer=setInterval(function(){
if($(".l-dialog-content-noimage").length>0){
var time=parseInt($(".l-dialog-content-noimage").find("span").html(),10);
if(time==0){
$.ligerDialog.confirm('统计时间过长,是否继续等待?', function (yes) {
if(yes){
$(".l-dialog-content-noimage").find("span").html(30);
} else{
clearInterval(window.timer);
$.ligerDialog.closeWaitting();//关闭等待窗口
}
});
}else{
time--;
$(".l-dialog-content-noimage").find("span").html(time);
}
}else{
window.console.log("clearInterval(window.timer)");
clearInterval(window.timer);
}
},1000)
$("#grid").empty();
queryData(userName,org_code,isNo,fromYearMonth,toYearMonth,system,pageNo,pageSize,flag);
}
}
/*
*查询数据
*/
function queryData(){
$.ajax({
url : "ChargeMs_queryChargeMsManage",
dataType : "json",
data : getParam(),
success : function(data) {
var result = data.result;
$("#no").hide();
var pages = Math.ceil(data.sumNo/pageSize);
laypage({
cont: 'page',
pages: pages, //可以叫服务端把总页数放在某一个隐藏域,再获取。假设我们获取到的是18
skip: true,
skin: 'molv', //皮肤
first: '首页', //将首页显示为数字1,。若不显示,设置false即可
last: '尾页', //将尾页显示为总页数。若不显示,设置false即可
groups: 3,
curr: 1,
jump: function(e, first) { //触发分页后的回调
if (!first) { //一定要加此判断,否则初始时会无限刷新
getPageData(e.curr);
}
}
});
buildHtml(result);
}
})
}
/*
*分页调用
*/
function getPageData(_pageNo){
var param=getParam();
param.pageNo=_pageNo;
$.ajax({
url: "ChargeMs_queryChargeMsManage",
dataType: "json",
data:param,
success: function (data) {
buildHtml(data.result);
}
})
}
/*
*构建表格
*/
function buildHtml(result){
idArr=[];//如果不需要翻页勾选,将此处去掉
var $grid = $("#grid");
var checkCount=0;//记录一页中勾选的个数
idOjbBuc={};
$grid.empty();
var title = "<tr class='tbl-header'><th></th><th><input type='checkbox' class='checkAll'/></th><th>用户编号</th><th>用户名称</th><th>区域</th><th>账单年月</th><th>上次结余(元)</th><th>本月费用(元)</th><th>本月应交</th> <th>是否交费</th>" +
"<th>操作</th></tr>";
$grid.append(title);
if(result.length>0){
queryLog('ChargeMs_queryChargeMsManage');
for(var i=0;i<result.length;i++){
var id=result[i].id+"";
idOjbBuc[result[i].id]=result[i];
var detail = "<a onclick=openWindow('bill/BillDetailBY.html?type=charge&month="+result[i].month+"&userNo="+result[i].userNo+"&dbsources="+result[i].systemType+"') >账单</a>";
var month = result[i].month+'';
var lastLeft = !!result[i].lastLeft?result[i].lastLeft.toFixed(2):0.00;
var monthPay = !!result[i].monthPay?result[i].monthPay.toFixed(2):0.00;
var needPay = !!result[i].needPay?result[i].needPay.toFixed(2):0.00;
var yearMonth = month.substring(0,4)+'-'+month.substring(4);
var str= $("<tr id='"+result[i].userNo+"' data-id='"+result[i].id+"'>"+
"<td>"+(i+1)+"</td>"+
"<td><input type='checkbox' data-id='"+result[i].id+"'/></td>"+
"<td>"+result[i].userNo+"</td>"+
"<td>"+result[i].userName+"</td><td>"+result[i].org_codeName+"</td>"+
"<td>"+yearMonth+"</td><td>"+lastLeft+"</td>" +
"<td>"+result[i].monthPay+"</td><td>"+needPay+"</td>"+
"<td>"+result[i].isPay+"</td><td>"+detail+"</td>"+
"</tr>");
//判断是否需要初始化勾选
if(idArr.indexOf(id)>-1){
str.find("input[type=checkbox]").prop("checked",true);
checkCount++;
}
$grid.append(str);
}
}else{
$grid.append("<tr><td colspan='8'>暂无数据</td></tr>");
}
//判断一页中全选的是否需要勾上
if(checkCount===pageSize){
$grid.find('.checkAll').prop("checked",true);
$('.table-fixed').find('.checkAll').prop("checked",true);//克隆的checkbox也需要勾选上
}
}
function searchCilck(){
var userName = $('#searchVal').val();
var org_code = $("#area").data("data-id") || '';
var isNo = $("#isfree").data("data-id") || '';
var fromYearMonth = $("#fromDate").val().replace('-',''); //查询上一个月的
var toYearMonth = $("#toDate").val().replace('-',''); //查询上一个月的
var system = $("#system").data("data-id");
if($('#area').val() == '') org_code = '';
if($('#isfree').val() == '') isNo = '';
if($('#system').val() == '') system = '';
//queryData(userName,yearMonth,system,isNo,pageNo,pageSize);
queryData(userName,org_code,isNo,fromYearMonth,toYearMonth,system,pageNo,pageSize)
}
/**
*弹出小窗口显示
*/
function openWindow(url){
if (win1) win1.close();
win1 = $.ligerDialog.open({ height: $(window).height(), url: url, width: $(window).width()-100 });
}
/**
*获取查询的条件
*/
function getParam(){
var obj={};
obj.startDate=$("#fromDate").val().replace(/-/g,"");//开始时间
obj.endDate=$("#toDate").val().replace(/-/g,"");//结束时间
obj.org_code=$("#area").data("data-id") || '';//所在区域
if($("#area").val() == "") obj.org_code = '';
obj.isNo=$("#isfree").data("data-id") || '';//是否收费
if($("#isfree").val() == "") obj.isNo = '';
obj.userName=$('#searchVal').val();//搜索用户名
obj.dbsources='BaseDao';
obj.pageNo=pageNo;
obj.pageSize=pageSize;
return obj;
}
</script> </body>
</html>
JQuery实现表格的全选和反选,以及分页勾选保存(laypage插件分页的使用)的更多相关文章
- jQuery版本引发的血案 iframe error 和 checkbox 无法勾选
问题介绍: 1.由于我们的项目里面用了很多Iframe,在初始话加载的时候页面就会报错.一开始调试很久没找到什么原因,看打印结果页面会被两次load,只能一步步找, 最后发现在document rea ...
- jQuery 判断多个 input checkbox 中至少有一个勾选
html ( 使用 TP 标签 ) : <volist name="health_tag" id="htag"> <input type=&q ...
- 三、WPF 全选,反选,以及获取选中行
页面代码 <TextBlock> <CheckBox Name="cbAllCreate" Click="CbAllCreate_Click" ...
- TreeView树,全选,反选,平级选操作
首先事件选择,选择的是MouseUp事件.为啥?因为凡是跟Check有关的,在选中父节点或者子节点,都会二次触发.然后发生的就是死循环. Up事件就可以避免二次触发.Down事件呢?那就触发After ...
- firefox(火狐)下 js中设置checkbox属性checked="checked"已有,但复选框却不显示勾选的原因
刚看到问题时以为是浏览器兼容性的原因,ie.google都能正常显示. 网上查询之后发现是jQuery的attr()方法用的不恰当. jQuery1.6之前使用attr()可以修改 ,从jQuery ...
- Axure 实现批量的勾选和反选
百度网盘:http://pan.baidu.com/s/1gf4RR2b 1.如何实现批量的勾选和反选的操作? 2.步骤 1)创建3个复选框.2个按钮(全选/反选) 2)设置全选按钮点击事件——选中“ ...
- Element UI表格组件技巧:如何简洁实现跨页勾选、跨页统计功能
业务场景 在使用Element UI的Table组件时,常常面对这样的业务需求: 表格数据的每一项都要提供勾选框,当切换分页时,能够记忆所有页面勾选的数据,以实现批量提交不同页面勾选数据的功能.并且, ...
- layui table 分页 记住之前勾选的数据
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Ext.js中树勾选的四种操作
最近在做控件优化的时候产品提了一个需求,对树的勾选要满足四种勾选方案: 1.点击一次根节点,当根节点和子节点均未选中的情况下,根节点和子节点全都选中. 2.第二次点击根节点,当根节点和部分或全部子节点 ...
随机推荐
- 使用CodeMaid自动程序排版[转]
前言 「使用StyleCop验证命名规则」这篇文章,指引开发人员透过StyleCop这个工具,来自动检验项目中产出的程序代码是否合乎命名规则. [Tool] 使用StyleCop验证命名规则 但是在项 ...
- C# 文本输入限制类型,datagridview单元格输入验证
1.只能输入double类型 private void textBoxX6_KeyPress(object sender, KeyPressEventArgs e) { { //数字0~9所对应的ke ...
- 【ARC062F】 Painting Graphs with AtCoDeer 点双连通分量+polya定理
Description 给定一张N点M边的无向图,每条边要染一个编号在1到K的颜色. 你可以对一张染色了的图进行若干次操作,每次操作形如,在图中选择一个简单环(即不经过相同点的环),并且将其颜色逆时针 ...
- GitHub 十大 CI 工具
简评:GitHub 上最受欢迎的 CI 工具. 持续集成(Continuous integration)指的是,频繁地(一天多次)将代码集成到主干. 持续集成工具让产品可以快速迭代,同时还能保持高质量 ...
- 题解 P3252 【[JLOI2012]树】
\(\Huge{[JLOI2012]树}\) 题目描述 在这个问题中,给定一个值S和一棵树.在树的每个节点有一个正整数,问有多少条路径的节点总和达到S.路径中节点的深度必须是升序的.假设节点1是根节点 ...
- 【语义分割】large kernel matters中GCN模块的pytorch实现
GCN模块的实现比较简单,在giuhub上看到两种实现,轻微不同 实现一:https://github.com/ycszen/pytorch-segmentation/blob/master/gcn. ...
- php 利用 json 传递数组之中文乱码最新解决办法
json好用,但是如果数据中有中文就会出乱子了,网上解决办法多半是设置utf-8编码或转换字符编码 以下是我的解决办法,利用php的urlencode.urldecode函数(其实也是一种转换编码吧) ...
- Apache 去掉 www
1 用phpstudy的网友打开“其他选项菜单”- “配置文件”-httpd-conf.找到 #LoadModule rewrite_module modules/mod_rewrite.so 把这一 ...
- R语言批量生成变量(变量名中含有参数)
我们经常会需要生成这样一类的变量,比如a1,a2,a3...... 这时候我们需要用到这两个函数:get()和assign() get()用法 get()函数只是在环境中搜索该变量名的变量,如果该变量 ...
- 静态区间第K小(整体二分、主席树)
题目链接 题解 主席树入门题 但是这里给出整体二分解法 整体二分顾名思义是把所有操作放在一起二分 想想,如果求\([1-n]\)的第\(k\)小怎么二分求得? 我们可以二分答案\(k\), \(O(n ...