Jquery 获取checkbox的checked问题


Posted in Javascript onNovember 16, 2011

注意: 操作checkbox的checked,disabled属性时jquery1.6以前版本用attr,    1.6以上(包含)建议用prop

1、根据id获取checkbox

 $("#Checkbox1");

2、获取所有的checkbox    

$("input[type='checkbox']");//或者$(":checkbox");

3、获取所有选中的checkbox  

  $("input:checkbox:checked");
  //或$("input[type='checkbox']:checked");
  //或$("input:[type='checkbox']:checked");

4、获取checkbox值
    用.val()获取

$("#Checkbox").val();

 5、获取多个选中的checkbox值   

var vals = [];
 $('input:checkbox:checked').each(function (index, item) {
 vals.push($(this).val());
 });

6、判断checkbox是否选中(jquery 1.6以前版本 用  $(this).attr("checked") 

  用prop查:选中时checked值为true,未选中时checked值为false

$("#cbCheckbox1").click(function () {
 if ($(this).prop("checked")) {
  alert("选中");
 } else {
  alert("没有选中");
 }
});

用attr查:选中checked值为checked,未选中时checked值为undefined

7、设置checkbox为选中状态  

$('input:checkbox').attr("checked", 'checked');

$('input:checkbox').prop("checked", true);

8、设置checkbox为不选中状态

$('input:checkbox').prop("checked", false);//或$('input:checkbox').attr("checked", '');

 9、设置checkbox为禁用状态(jquery<1.6用attr,jquery>=1.6建议用prop)   

$("input[type='checkbox']").attr("disabled", "disabled");
//或$("input[type='checkbox']").attr("disabled", true);
//或$("input[type='checkbox']").prop("disabled", true);
//或$("input[type='checkbox']").prop("disabled", "disabled");

10、设置checkbox为启用状态(jquery<1.6用attr,jquery>=1.6建议用prop)

$("input[type='checkbox']").removeAttr("disabled");
//或$("input[type='checkbox']").attr("disabled", false);
//或$("input[type='checkbox']").prop("disabled", "");

下面是其他网友的补充

事实证明一切,自己测试了N遍,发现网上的说法和自己以前的理解都是错的,不知道大家有没发现.

下面来看看网上大多资料的说法

转别人的一些东西:
jquery判断checkbox是否被选中
在html的checkbox里,选中的话会有属性checked="checked"。
如果用一个checkbox被选中,alert这个checkbox的属性"checked"的值alert($(#xxx).attr("checked")),会打印出"true",而不是"checked"!
如果没被选中,打印出的是"undefined"。
注意红色的部分,这里说到

$("#chekbox").sttr("checked")//should be print "true" , not "checked"

经过测试,证明上面说法有问题

<script type="text/javascript"> 
$(function() { 
$("#button").click(function() { 
alert($("#checkbox").attr("checked")); 
}); 
}); 
</script> 
<input type="checkbox" name="checkbox" id="checkbox">
<input type="button" id="button" value="Click Me">

//上面得出的结果是: 如果勾上checkbox,会打印出 “checked” , 如果取消打勾 会打印出 "undefined"
实验证明Jquery获取checked的值得打印出"true"是错误的
举一反三:
而且发现Jquery获取已经被勾上的checkbox,永远都是"checked" 这让人费解,如果有人知道为什么,可以告诉我一下,哈~~

<script type="text/javascript"> 
$(function() { 
$("#button").click(function() { 
alert($("#checkbox").attr("checked")); 
}); 
}); 
</script> 
<input type="checkbox" name="checkbox" id="checkbox" checked>
<input type="button" id="button" value="Click Me">

//注意红色位置,如果默认checkbox为checked状态,测试会发现,把勾去掉也是只会输出"checked" , 表示不理解为什么 Jquery会这样
解决方法,还是用document.get获取吧:

<script> 
function getcheckbox(){ 
var test = document.getElementById("checkbox").checked; 
alert(test); 
} 
</script> 
<input type="checkbox" name="checkbox" id="checkbox">
<input type="button" id="button" value="Click Me" onclick="getcheckbox()">

//选中为"true",取消选中为"false"
如果有错,希望指正。网上搜索的问题都是一个帖子转N遍,自己测试证明一下

checkbox选中与取消选择

1.html

<form>
 <input type="checkbox" name="items" value="足球" />足球
 <input type="checkbox" name="items" value="篮球" />篮球
 <input type="checkbox" name="items" value="羽毛球" />羽毛球
</form>

2.js

//全选中
$("input:checkbox").prop("checked","checked");
//取消选中
$("input:checkbox").removeAttr("checked");

注意:使用attr(),会发现代码那里的checked="checked",但是页面input上没有显示出来

Javascript 相关文章推荐
ext jquery 简单比较
Apr 07 Javascript
自制轻量级仿jQuery.boxy对话框插件代码
Oct 26 Javascript
jQuery JSON的解析方式分享
Apr 05 Javascript
javascript 数字格式化输出的实现代码
Dec 10 Javascript
JS+CSS实现带关闭按钮DIV弹出窗口的方法
Feb 27 Javascript
JavaScript中this详解
Sep 01 Javascript
js动态生成Html元素实现Post操作(createElement)
Sep 14 Javascript
jQuery实现的网页换肤效果示例
Sep 20 Javascript
微信js-sdk地理位置接口用法示例
Oct 12 Javascript
jQuery实现通过方向键控制div块上下左右移动的方法【测试可用】
Apr 26 jQuery
微信小程序实现红包功能(后端PHP实现逻辑)
Jul 11 Javascript
JavaScript代码实现微博批量取消关注功能
Feb 05 Javascript
JS 操作符整理[推荐收藏]
Nov 15 #Javascript
js 关于=+与+=日期函数使用说明(赋值运算符)
Nov 15 #Javascript
关于js datetime的那点事
Nov 15 #Javascript
基于jquery封装的一个js分页
Nov 15 #Javascript
js 利用className得到对象的实现代码
Nov 15 #Javascript
基于jquery的web页面日期格式化插件
Nov 15 #Javascript
jQuery EasyUI API 中文文档 - Dialog对话框
Nov 15 #Javascript
You might like
实用函数2
2007/11/08 PHP
php学习之运算符相关概念
2011/06/09 PHP
通过php修改xml文档内容的方法
2015/01/23 PHP
PHP数据库操作四:mongodb用法分析
2017/08/16 PHP
PHPMAILER实现PHP发邮件功能
2018/04/18 PHP
PHP8.0新功能之Match表达式的使用
2020/07/19 PHP
jQuery新闻滚动插件 jquery.roller.js
2011/06/27 Javascript
Jquery 表格合并的问题分享
2011/09/17 Javascript
web基于浏览器的本地存储方法应用
2012/11/27 Javascript
Jquery:ajax实现翻页无刷新功能代码
2013/08/05 Javascript
自己实现ajax封装示例分享
2014/04/01 Javascript
JQuery $.each遍历JavaScript数组对象实例
2014/09/01 Javascript
js实现简单计算器
2015/11/22 Javascript
jQuery插件cxSelect多级联动下拉菜单实例解析
2016/06/24 Javascript
javascript 显示全局变量与隐式全局变量的区别
2017/02/09 Javascript
vue.js开发环境安装教程
2017/03/17 Javascript
微信小程序 动态绑定事件并实现事件修改样式
2017/04/13 Javascript
element UI upload组件上传附件格式限制方法
2018/09/04 Javascript
inquirer.js一个用户与命令行交互的工具详解
2019/05/18 Javascript
解决vue admin element noCache设置无效的问题
2019/11/12 Javascript
给Python中的MySQLdb模块添加超时功能的教程
2015/05/05 Python
Python实时获取cmd的输出
2015/12/13 Python
Python实现简单的多任务mysql转xml的方法
2017/02/08 Python
python——全排列数的生成方式
2020/02/26 Python
Pycharm修改python路径过程图解
2020/05/22 Python
Python绘图之二维图与三维图详解
2020/08/04 Python
python两种获取剪贴板内容的方法
2020/11/06 Python
Python爬虫中Selenium实现文件上传
2020/12/04 Python
英国豪华真皮和布艺沙发销售网站:Darlings of Chelsea
2018/01/05 全球购物
军训生自我鉴定范文
2013/12/27 职场文书
高一军训的心得体会
2014/09/01 职场文书
离婚协议书的书写要求
2014/09/17 职场文书
撤诉申请书法院范本
2015/05/18 职场文书
小学三年级语文教学反思
2016/03/03 职场文书
Python Django搭建文件下载服务器的实现
2021/05/10 Python
MySQL数据库实验实现简单数据库应用系统设计
2022/06/21 MySQL