0

0

使用 jQuery 实现多区域内复选框的“全选/全不选”功能

花韻仙語

花韻仙語

发布时间:2025-07-23 13:54:32

|

592人浏览过

|

来源于php中文网

原创

使用 jQuery 实现多区域内复选框的“全选/全不选”功能

本文详细介绍了如何利用 jQuery 实现网页中多组复选框的“全选/全不选”功能。通过为每个独立的复选框组定义特定HTML结构和类名,并编写相应的jQuery事件处理逻辑,可以高效管理各组内复选框的选中状态。教程涵盖“全选”按钮控制同组内所有复选框,以及单个复选框状态变化时更新“全选”按钮的核心交互逻辑,并提供完整代码示例。

在web开发中,经常会遇到需要对一组复选框进行“全选”或“全不选”操作的需求。当页面上存在多个独立的复选框组时,这种需求会变得更加复杂,因为每个组内的“全选”功能都应该只影响当前组内的复选框,而不会影响其他组。本教程将详细阐述如何利用 jquery 优雅地实现这一功能。

1. HTML 结构设计

为了使 jQuery 能够准确识别每个复选框组及其内部的“全选”按钮和普通复选框,我们需要设计一个清晰的 HTML 结构。关键在于为每个独立的复选框组添加一个共同的父级容器,并为“全选”复选框添加一个特定的类名。

我们将使用一个 div 元素作为每个复选框组的容器,并为其添加 myDiv 类。每个组内的“全选”复选框则统一添加 selectAll 类。

Select All

Action 1

Action 2

Action 3

Select All

Action 27

Action 28

Action 29

Action 30

Action 31

说明:

  • class="myDiv":标识一个独立的复选框组。
  • class="selectAll":标识该组内的“全选”复选框。
  • name="action":所有复选框可以共享相同的 name 属性,这不影响本教程的逻辑。

2. jQuery 逻辑实现

接下来,我们将编写 jQuery 代码来处理复选框的交互逻辑。这主要包括两部分:处理“全选”复选框的点击事件,以及处理单个复选框的点击事件。

2.1 处理“全选”复选框的点击事件

当用户点击某个“全选”复选框时,我们需要根据其选中状态,同步更新其所在组内的所有其他复选框的选中状态。

$('.selectAll').on('click', function() {
  // 获取当前“全选”复选框的选中状态
  let isSelected = $(this).is(':checked');

  // 找到当前“全选”复选框的父级组(.myDiv),然后在其内部查找所有复选框
  // 并将它们的选中状态设置为与“全选”复选框一致
  $(this).parents('.myDiv').find('input[type="checkbox"]').prop('checked', isSelected);
});

解释:

Snowy(SnowyAdmin)快速开发平台3.5.1
Snowy(SnowyAdmin)快速开发平台3.5.1

Snowy(SnowyAdmin)是国内首个国密前后端分离快速开发平台,集成国密加解密插件, 软件层面完全符合等保测评要求,同时实现国产化机型、中间件、数据库适配,是您的不二之选! 技术框架与密码结合,让更多的人认识密码,使用密码;更是让前后分离“密”不可分。采用SpringBoot+MybatisPlus+AntDesignVue+Vite 等更多组件及前沿技术开发,注释丰富,代码简洁,开箱即用

下载
  • $('.selectAll').on('click', function() { ... });:为所有带有 selectAll 类的复选框绑定点击事件。
  • $(this).is(':checked'):获取当前被点击的“全选”复选框的选中状态(true 或 false)。
  • $(this).parents('.myDiv'):向上遍历 DOM 树,找到当前 selectAll 复选框最近的、带有 myDiv 类的父元素,这确保了操作仅限于当前组。
  • .find('input[type="checkbox"]'):在找到的 .myDiv 组内,查找所有 input 类型为 checkbox 的元素。
  • .prop('checked', isSelected):设置这些找到的复选框的 checked 属性,使其与 isSelected 的值保持一致。

2.2 处理单个复选框的点击事件

当用户点击组内某个非“全选”的普通复选框时,我们需要检查该组内所有普通复选框的选中状态,并据此更新“全选”复选框的状态。具体逻辑是:如果所有普通复选框都被选中,则“全选”复选框也应该被选中;否则,“全选”复选框应该处于未选中状态。

$('input:not(".selectAll")').on('click', function() {
  // 获取当前复选框所在的父级组(.myDiv)
  let $parentDiv = $(this).parents('.myDiv');

  // 获取当前组内所有非“全选”的普通复选框
  let $normalCheckboxes = $parentDiv.find('input:not(".selectAll")');

  // 获取当前组内被选中的普通复选框的数量
  let numberInputChecked = $normalCheckboxes.filter(':checked').length;

  // 获取当前组内普通复选框的总数量
  let numberInput = $normalCheckboxes.length;

  // 获取当前组的“全选”复选框
  let $selectAllCheckbox = $parentDiv.find('.selectAll');

  // 如果所有普通复选框都被选中,则“全选”复选框也应被选中
  if (numberInput === numberInputChecked) {
    $selectAllCheckbox.prop('checked', true);
  } else {
    // 否则,“全选”复选框应处于未选中状态
    $selectAllCheckbox.prop('checked', false);
  }
});

解释:

  • $('input:not(".selectAll")').on('click', function() { ... });:为所有不是 selectAll 类的 input 复选框绑定点击事件。
  • let $parentDiv = $(this).parents('.myDiv');:同样,先定位到当前复选框所属的 .myDiv 组。
  • $parentDiv.find('input:not(".selectAll")'):在当前组内找到所有非“全选”的复选框。
  • .filter(':checked').length:从上述普通复选框中筛选出已选中的,并获取其数量。
  • $normalCheckboxes.length:获取普通复选框的总数量。
  • 通过比较选中数量和总数量,来决定“全选”复选框的 checked 属性。

3. 完整示例代码

将上述 HTML 结构和 jQuery 逻辑结合起来,即可实现所需功能。请确保在运行代码前引入 jQuery 库。




    
    
    多区域复选框全选功能
    
    
    



    
Select All (Group 1)

Item 1.1

Item 1.2

Item 1.3

Select All (Group 2)

Item 2.1

Item 2.2

Item 2.3

Item 2.4

Item 2.5

4. 注意事项与总结

  • 类名约定: 使用 myDiv 和 selectAll 这样的通用类名,可以使代码更具可读性和可维护性,方便在多个页面或组件中复用。
  • 作用域限定: parents('.myDiv').find(...) 的组合使用是实现局部“全选”功能的关键。它确保了操作只在当前复选框组内部进行,避免了跨组影响。
  • 性能考量: 对于包含大量(成百上千个)复选框的复杂页面,频繁的 DOM 操作可能会影响性能。但对于大多数常见应用场景,本教程提供的方法性能是完全足够的。
  • 初始状态: 如果页面加载时某些复选框默认是选中状态,你可能需要在页面加载完成后执行一次检查,以正确设置初始的“全选”复选框状态。这可以通过在 $(document).ready() 中触发一次 click 事件或手动调用逻辑来实现。
  • 用户体验: 考虑为“全选”复选框添加额外的样式,使其更易于识别。

通过以上步骤,我们成功地实现了在多个独立 div 区域内管理复选框的“全选/全不选”功能。这种方法结构清晰,逻辑严谨,是处理此类交互需求的有效实践。

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

150

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

307

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

390

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

490

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

177

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

171

2024.02.23

html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

596

2023.06.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 2.7万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

NumPy 教程
NumPy 教程

共44课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号