专注WEB开发 分享经验,沉淀知识

checkbox的全选与取消操作

 作者:chenxing  时间:2017-01-20 23:15  评论:0

checkbox的全选功能是非常常见,特别是在一下列表的批量操作上,或者有众多的checkbox的时候。

checkbox的全选功能是非常常见,特别是在一下列表的批量操作上,或者有众多的checkbox的时候。

这里分析一下本人自己写的这部分功能。

贴代码,如下:

/**
 *checkbox全选与取消
 *
 *场景描述:有一个ktv列表,可以全选进行删除。
 *一个全选checkbox id为selectAll,列表checkbox,name为ktv_id
 */

 //解决点击全选checkbox的列表checkbox状态(全部选中或者全部不选)
$('#selectAll').click(function(){
oif($(this).is(':checked')){
o$('input[name="ktv_id[]"]').prop('checked',true);//必须用prop,不能用attr 第二次则无法显示备选状态
o}else{
o$('input[name="ktv_id"]').removeAttr('checked');
o}
})
//解决点击列表中的checkbox,全选checkbox的状态(当列表中checkbox全部选中时,全选的checkbox为选中状态,否则为不选状态)
//通对比总checkbox数量和被选选中的checkbox数量是否相等
$('input[name="ktv_id[]"]').click(function(){
o$ktvNum= $('input[name="ktv_id[]"]').length;
o$ktvSelectNum = $('input[name="ktv_id[]"]').filter(':checked').length;
oif($ktvNum == $ktvSelectNum){
o$('#selectAll').prop('checked',true);
o}else{
o$('#selectAll').removeAttr('checked',true);
o}
o
})

代码逻辑很简单,但有3个细节需要注意:

1.对checkbox属性checked的设置。这里采用的是prop而非attr,实践证明当你用attr设置的时候第一次是进行全选的时候貌似是一切正常,当你再次进行全选的时候,发现列表中的checkbox没有被勾选,不过当你debug查看元素的checkbox确实true。完美的解决方式就是用prop替代attr。

2.采用filter获取比勾选checkbox的元素集合。这里无法直接通过check属性进行选取。以为通过debug查看,你勾选下的元素是不会显示改变的checked值。

3.checked中的name一般用类似数组的形式处理(形如:name="ktv_id[]"),这样用js获取的时候或者传递到后端的时候这部分的数据是以数组的形式保存。可以取不一样的名称。当但元素很多的时候建用数组形式。

好吧,在表单元素中jq操作checkbox还是挺有意思的,总之,多实践。

除特别注明外,本站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/26.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

  • 暂无评论^_^
站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

3165

271854

158

交流群:157451741

新浪微博:草莽兴

 近期文章

聊聊国产化

 2024-08-24 15:56  102

内网穿透工具frp配置详情

 2024-07-18 22:30  202

mac在终端复制出现乱码00~ *** 01~

 2024-07-16 20:38  44

php html生成图片

 2024-07-08 20:25  85

scp命令使用说明

 2024-07-06 12:14  118

如何在当前目录打开终端

 2024-07-04 14:54  87

 最新评论

 tradeOff: 08月30日 10:19
在某些领域国产化是一个迫不得已的事儿
来源: 聊聊国产化
 sue: 07月03日 10:24
可以
来源: 微信小程序如何获取单个input值
 流年: 07月02日 11:31
不错的尝试
来源: 博客系统如何用markdown编辑器发布文章
 诚心: 09月29日 23:01
学到了
来源: 如何一次性推送百万级别的消息
 Nick: 04月14日 12:26
网上的资料还是太老,都只是取一个元素,解决了一大难题
来源: redis set集合取出一组数据并删除
 skywalker: 11月03日 18:21
简洁明了
来源: mysql 获取某个日期的前一天或后一天