js/jQuery常见操作 之 jQuery操作复选框的常见问题

2023-12-14 06:11:44

1. js/jQuery的其他一些常见基础操作

2. 全选/全不选问题

2.1 效果

  • 如下:
    在这里插入图片描述

2.2 实现代码

2.2.1 简单js实现

  • 如下:
    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="utf-8">
    		<title></title>
    	</head>
    	<body>
    		
    		<form method="post" action="">
    			
    			您想饲养的狗狗有?
    			<input type="checkbox" id="checkAllOrNo"/>全选/全不选
    			 
    			<br />
    			<input type="checkbox" name="items" value="边牧"/>边牧
    			<input type="checkbox" name="items" value="柯基"/>柯基
    			<input type="checkbox" name="items" value="秋田犬"/>秋田犬
    			<input type="checkbox" name="items" value="金毛"/>金毛
    			
    			<br />
    			<input type="button" id="checkAll" value="全选"/>
    			<input type="button" id="checkNoOne" value="全不选"/>
    			<input type="button" id="fanxuan" value="反选"/>
    			<input type="button" id="btnAllOrNO" value="全选/全不选"/>
    			<input type="button" id="commit" value="提交"/>
    			
    		</form>
    		
    		<script type="text/javascript">
    			
    			//1. 全选
    			var all = document.getElementById("checkAll");
    			function funAll(){
    				var box = document.getElementsByName("items");
    				for(var i =0;i<box.length;i++){
    					// alert(box[i].value);
    					box[i].checked = true;
    				}
    			}
    			all.onclick = funAll;
    			
    			//2.全不选
    			var allNo = document.getElementById("checkNoOne");
    			function funAllNo(){
    				var box = document.getElementsByName("items");
    				for(var i =0;i<box.length;i++){
    					box[i].checked = false;
    				}
    			}
    			allNo.onclick = funAllNo;
    			
    			//3.反选(直接取反)
    			var fan = document.getElementById("fanxuan");
    			fan.onclick = function(){
    				var box = document.getElementsByName("items");
    				for(var i =0;i<box.length;i++){	
    					// if(box[i].checked == false){
    					// 	box[i].checked = true;
    					// }else{
    					// 	box[i].checked = false;
    					// }
    					//可以将整个if else优化为,如下:
    					box[i].checked = !box[i].checked;//直接取反
    				}
    			}
    			
    			//4.全选/全不选----按钮操作
    			var btn_check_all = document.getElementById("btnAllOrNO");
    			btn_check_all.onclick = function(){
    				var boxes = document.getElementsByName("items");
    				var flag = false;//false-全不选  true-全选
    				for(var i =0; i<boxes.length; i++){
    					if(boxes[i].checked == false){
    						flag = true;//只要存在没有选中的话,就进行反选
    						break;
    					}
    				}
    				// alert(flag);
    				if(flag){
    					//执行全选函数
    					funAll();
    				}else{
    					//执行全不选函数
    					funAllNo();
    				}
    			}
    			
    			//5 全选/全不选——复选框操作
    			//5.1 点击全选复选框
    			var checkAllOrNo_2 = document.getElementById("checkAllOrNo");//复选框全选/全不选
    			checkAllOrNo_2.onclick = function(){
    				var box = document.getElementsByName("items");
    				for(var i =0; i<box.length; i++){
    					box[i].checked = this.checked;//即:选中状态与全选/全不选的复选框保持一致即可
    				}
    			}
    			
    			//5.2 点击各项目复选框
    			var boxAll_2 = document.getElementsByName("items");
    			for(var i=0;i<boxAll_2.length;i++){
    				boxAll_2[i].onclick = function(){
    					checkAllOrNo_2.checked = true;//点击任何一个复选框,全选复选框都先设置为选中状态
    					for(var i=0; i<boxAll_2.length; i++){
    						if(boxAll_2[i].checked == false){
    							//只要有没有选中,全选复选框就设置未选中
    							checkAllOrNo_2.checked = false;
    							break;
    						}
    					}
    				}
    			}
    			
    			//6.提交 获取选中的复选框
    			var data = document.getElementById("commit");
    			data.onclick = function(){
    				var box = document.getElementsByName("items");
    				var commmitData = "";
    				for(var i =0; i<box.length; i++){
    					if(box[i].checked == true ){
    						commmitData += box[i].value + ",";
    					}
    				}
    				var resultData = commmitData.substring(0,commmitData.length-1);
    				alert(resultData);
    			}
    			
    		</script>
    		
    		
    	</body>
    </html>
    

2.2.2 jQuery实现

2.2.2.1 注意语法(区别jQuery版本)
  • 下面以全选为例,如下:
    • 复杂写法:
      //1. 全选---复杂点写法
      var all = document.getElementById("checkAll");
      function funAll(){
      	// 1.1 循环处理
      	$("input[name='items']").each(function(){
      		// 下面两种写法高低版本的jQuery均可以
      		// $(this).attr("checked",true); 
      		this.checked = true;
      
      		// prop 适合高版本的jQuery
      		//$(this).prop("checked",true);
               	});
      	// 1.2 直接根据name处理
      	// $("input[name='items']").attr("checked", true);
      
      	// 注意:prop 适合高版本的jQuery
      	// $("input[name='items']").prop("checked", true); 
      }
      all.onclick = funAll;
      
    • 优化写法:
      $("#checkAll").click(function(){
      	$("input[name='items']").attr("checked", true);
      });
      
  • 再以全选/全不选为例(非按钮的情况),如下:
    • 点击 全选/全不选 ——复杂点逻辑:
      //5.1.1 点击 全选/全不选 复选框---使用多层this
      $("#checkAllOrNo").click(function(){
      	var parentFlag = this.checked;
      	$("input[name='items']").each(function(){
      		this.checked = parentFlag;
      	});
      });
      
    • 点击 全选/全不选 ——简单点逻辑
      //5.1.2 点击 全选/全不选 复选框----使用s(":checked")
      $("#checkAllOrNo").click(function(){
      	$("input[name='items']").each(function(){
      		this.checked = $("#checkAllOrNo").is(":checked");
      	});
      });
      
    • 点击各项目:
      //5.2 点击各项目复选框
      $("input[name='items']").each(function(){
      	$(this).click(function(){
      		// 点击任何一个复选框,全选/不全选 复选框都先设置为选中状态
      		$("#checkAllOrNo").attr("checked",true);
      		// 然后再循环所有的复选框,是否有未选中的
      		$("input[name='items']").each(function(){
      			if(!this.checked){
      				$("#checkAllOrNo").attr("checked",false);
      				return;
      			}
      		});
      	});
      });
      
  • 关于jQuery版本的一些可以看下面的文章,3.6中有介绍,
    js/jQuery 的一些常用操作(js/jQuery获取表单元素值 以及 清空元素值的各种实现方式)——附测试例子,拿来即能实现效果.
2.2.2.2 完整代码实现
  • 各情况代码,如下:
    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="utf-8">
    		<title></title>
    		<!-- <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.js"></script> -->
    		<script src="https://cdn.bootcdn.net/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
    
    	</head>
    	<body>
    		
    		<form method="post" action="">
    			
    			您想饲养的狗狗有?
    			<input type="checkbox" id="checkAllOrNo"/>全选/全不选
    			 
    			<br />
    			<input type="checkbox" name="items" value="边牧"/>边牧
    			<input type="checkbox" name="items" value="柯基"/>柯基
    			<input type="checkbox" name="items" value="秋田犬"/>秋田犬
    			<input type="checkbox" name="items" value="金毛"/>金毛
    			
    			<br />
    			<input type="button" id="checkAll" value="全选"/>
    			<input type="button" id="checkNoOne" value="全不选"/>
    			<input type="button" id="fanxuan" value="反选"/>
    			<input type="button" id="btnAllOrNO" value="全选/全不选"/>
    			<input type="button" id="commit" value="提交"/>
    			
    		</form>
    		
    		<script type="text/javascript">
    			
    			//1. 全选---复杂点写法
    			var all = document.getElementById("checkAll");
    			function funAll(){
    				// 1.1 循环处理
    				$("input[name='items']").each(function(){
    					// 下面两种写法高低版本的jQuery均可以
    					// $(this).attr("checked",true); 
    					this.checked = true;
    
    					// prop 适合高版本的jQuery
    					//$(this).prop("checked",true);
                	});
    				// 1.2 直接根据name处理
    				// $("input[name='items']").attr("checked", true);
    
    				// 注意:prop 适合高版本的jQuery
    				// $("input[name='items']").prop("checked", true); 
    			}
    			// all.onclick = funAll;
    
    			// 1. 全选---简单点写法
    			$("#checkAll").click(function(){
    				$("input[name='items']").attr("checked", true);
    			});
    			
    			//2.全不选
    			$("#checkNoOne").click(function(){
    				$("input[name='items']").attr("checked", false);
    			});
    			
    			//3.反选(直接取反)
    			$("#fanxuan").click(function(){
    				$("input[name='items']").each(function(){
    					this.checked = !(this.checked);//直接取反
    				});
    			});
    			
    			//4.全选/全不选----按钮操作
    			$("#btnAllOrNO").click(function(){
    				var selectedNum = 0;//0-全不选  >0-全选
    				$("input[name='items']:not(:checked)").each(function(){
    					selectedNum ++;//计算没有选中的项目个数
    				});
    				if(selectedNum > 0){
    					// 只要存在没有选中的话,就进行全选
    					$("input[name='items']").attr("checked", true);
    				}else{
    					// 全不选
    					$("input[name='items']").attr("checked", false);
    				}
    			});
    			
    			//5 全选/全不选——复选框操作
    			//5.1.1 点击 全选/全不选 复选框---使用多层this
    			// $("#checkAllOrNo").click(function(){
    			// 	var parentFlag = this.checked;
    			// 	$("input[name='items']").each(function(){
    			// 		this.checked = parentFlag;
    			// 	});
    			// });
    
    			//5.1.2 点击 全选/全不选 复选框----使用s(":checked")
    			$("#checkAllOrNo").click(function(){
    				$("input[name='items']").each(function(){
    					// 选中状态与 全选/全不选 的复选框保持一致即可
    					this.checked = $("#checkAllOrNo").is(":checked");
    				});
    			});
    
    			//5.2 点击各项目复选框
    			$("input[name='items']").each(function(){
    				$(this).click(function(){
    					// 点击任何一个复选框,全选/不全选 复选框都先设置为选中状态
    					$("#checkAllOrNo").attr("checked",true);
    					// 然后再循环所有的复选框,是否有未选中的
    					$("input[name='items']").each(function(){
    						if(!this.checked){
    							$("#checkAllOrNo").attr("checked",false);
    							return;
    						}
    					});
    				});
    			});
    			
    			//6.提交 获取选中的复选框
    			// 6.1 拼接字符串写法
    			$("#commit").click(function(){
    				var commmitData = "";
    				$("input[name='items']:checked").each(function(){
    					commmitData += $(this).val() + ",";
    				});
    				var resultData = commmitData.substring(0,commmitData.length-1);
    				alert(resultData);
    			});
    
    			// 6.2 数组写法
    			$("#commit").click(function(){
    				var commmitData = [];
    				$("input[name='items']:checked").each(function(){
    					commmitData.push($(this).val());
    				});
    				alert(commmitData);
    			});
    			
    		</script>
    		
    	</body>
    </html>
    

3. jQuery实现点击 行tr 实现checkBox选中 + 翻页勾选问题

3.1 jQuery实现点击 行tr 获取td中checkBox的值

3.1.1 方式1

  • 实现代码如下:
    // 1.1 点击tr获取tr中是checkbox的td的值----方式1
    $("#dogs_data tr").each(function(){
        var current = $(this);
        current.click(function(){
            var box = $(this).find(":checkbox");
            console.log(box);
            console.log(box.val());
        });
    });
    
  • 效果如下:
    在这里插入图片描述

3.1.2 方式2

  • 实现代码,如下:
    // 1.2 点击tr获取tr中是checkbox的td的值----方式2
    $("#dogs_data tr").each(function(){
        $(this).click(function(){
            var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
            console.log(box);
            console.log(box.value);//因为是标签,取值用.value
        });
    });
    
  • 实现效果,如下:
    在这里插入图片描述

3.2 jQuery实现点击 行tr 实现checkBox选中或取消

3.2.1 点击 tr 时,checkbox选中或取消

  • 实现代码,如下:
    $("#dogs_data tr").each(function(){
        $(this).click(function(){
            var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
            box.checked = !box.checked;// 直接取反
        });
    });
    
  • 实现效果,如下:
    在这里插入图片描述

3.2.2 点击 首行tr 时,实现全选或全不选

  • 实现代码如下:
    // 2.2 点击首行tr时(表头),实现全选或全不选
    $("#dogs_data tr:eq(0)").each(function(){
        $(this).click(function(){
            var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
            box.checked = !box.checked;// 直接取反
            $("input[name='dogIds']").each(function(){
                this.checked = box.checked;// 数据行的选中状态与首行的选中状态保持一致
            });
        });
    });
    
  • 实现效果如下:
    在这里插入图片描述

3.2.3 点击非首行tr时(数据列表行),全选或全不选自动切换

  • 实现代码如下:
    // 2.3 点击非首行tr时(数据列表行),全选或全不选自动切换
    $("#dogs_data tr:gt(0)").each(function(){
        $(this).click(function(){
            var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
            box.checked = !box.checked; // 数据行直接取反
            $("#checkAllOrNo").attr("checked",true);// 数行先设置选中
    
            // 然后循环数据行的checkbox,如果有未选中的,取消首行选中(为了少循环次数,直接从not(:checked)中循环)
            $("input[name='dogIds']:not(:checked)").each(function(){
                $("#checkAllOrNo").attr("checked",false);// 如果存在任意一个未选中,直接取消选中
                return;
            });
        });
    });
    
  • 效果如下(不是视频,不是很明显,需要的还需自己测试):
    在这里插入图片描述

3.3 翻页勾选问题

  • 如果想,支持翻页勾选,那就把每次勾选的缓存在页面中的一个输入框里,然后勾选一个追加一个,这个参考上面取值的方式直接拼接即可实现,此处就不再多说了。

3.4 附上述操作tr的全代码

  • 如下:
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <!-- <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.js"></script> -->
        <script src="https://cdn.bootcdn.net/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
    
        <style>
            table {
                border-collapse: collapse;
            }
            table tr th,td{
                border: 1px solid;
                width: 60px;
                text-align: center;
            }
    
            thead tr:hover{
                background-color: rgb(255, 127, 127);
            }
            tbody tr:hover{
                background-color: aquamarine;
            }
        </style>
    </head>
    <body>
    
    
    
        <table celllspacing="0" id="dogs_data">
            <thead>
                <tr>
                    <th>
                        <input type="checkbox" id="checkAllOrNo" />
                    </th>
                    <th>编号</th>
                    <th>姓名</th>
                    <th>年龄</th>
                </tr>
            </thead>
            <tbody>
                <tr>
                    <td>
                        <input type="checkbox" name="dogIds" value="A1001"/>
                    </td>
                    <td>A1001</td>
                    <td>麦兜</td>
                    <td>3</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox" name="dogIds" value="A1002"/>
                    </td>
                    <td>A1002</td>
                    <td>贝塔</td>
                    <td>2</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox" name="dogIds" value="A1003"/>
                    </td>
                    <td>A1003</td>
                    <td>泡泡</td>
                    <td>6</td>
                </tr>
            </tbody>
        </table>
    
        <script>
            // 1.1 点击tr获取tr中是checkbox的td的值----方式1
            // $("#dogs_data tr").each(function(){
            //     var current = $(this);
            //     current.click(function(){
            //         var box = $(this).find(":checkbox");
            //         console.log(box);
            //         console.log(box.val());
            //     });
            // });
    
            // 1.2 点击tr获取tr中是checkbox的td的值----方式2
            // $("#dogs_data tr").each(function(){
            //     $(this).click(function(){
            //         var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
            //         console.log(box);
            //         console.log(box.value);// 因为是标签,取值用.value
            //     });
            // });
    
            // 2.1 点击 行tr 实现checkBox选中或取消
            // $("#dogs_data tr").each(function(){
            //     $(this).click(function(){
            //         var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
            //         box.checked = !box.checked;// 直接取反
            //     });
            // });
    
            // 2.2 点击首行tr时(表头),实现全选或全不选
            $("#dogs_data tr:eq(0)").each(function(){
                $(this).click(function(){
                    var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
                    box.checked = !box.checked;// 直接取反
                    $("input[name='dogIds']").each(function(){
                        this.checked = box.checked;// 数据行的选中状态与首行的选中状态保持一致
                    });
                });
            });
    
            // 2.3 点击非首行tr时(数据列表行),全选或全不选自动切换
            $("#dogs_data tr:gt(0)").each(function(){
                $(this).click(function(){
                    var box = this.firstElementChild.firstElementChild;//获取checkbox元素标签
                    box.checked = !box.checked; // 数据行直接取反
                    $("#checkAllOrNo").attr("checked",true);// 数行先设置选中
    
                    // 然后循环数据行的checkbox,如果有未选中的,取消首行选中(为了少循环次数,直接从not(:checked)中循环)
                    $("input[name='dogIds']:not(:checked)").each(function(){
                        $("#checkAllOrNo").attr("checked",false);// 如果存在任意一个未选中,直接取消选中
                        return;
                    });
                });
            });
    
        </script>
    </body>
    </html>
    

文章来源:https://blog.csdn.net/suixinfeixiangfei/article/details/134722886
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。