首页IT科技jquery实现全选和反选(使用 jQuery 为复选框设置“选中”)

jquery实现全选和反选(使用 jQuery 为复选框设置“选中”)

时间2025-06-17 08:51:49分类IT科技浏览4194
导读:问题描述: 我想做这样的事情来使用 jQuery 勾选 checkbox:...

问题描述:

我想做这样的事情来使用 jQuery 勾选 checkbox:

$(".myCheckBox").checked(true);

或者

$(".myCheckBox").selected(true);

这样的事情存在吗?

解决方案1:

huntsbot.com汇聚了国内外优秀的初创产品创意             ,可按收入             、分类等筛选                  ,希望这些产品与实践经验能给您带来灵感            。

现代 jQuery

使用 .prop():

$(.myCheckbox).prop(checked, true); $(.myCheckbox).prop(checked, false);

DOM API

如果您只使用一个元素      ,则始终可以只访问底层 HTMLInputElement 并修改其 .checked 属性:

$(.myCheckbox)[0].checked = true; $(.myCheckbox)[0].checked = false;

使用 .prop() 和 .attr() 方法代替此方法的好处是它们将对所有匹配的元素进行操作                   。

jQuery 1.5.x 及以下

.prop() 方法不可用             ,因此您需要使用 .attr()      。

$(.myCheckbox).attr(checked, true); $(.myCheckbox).attr(checked, false);

请注意                   ,这是 the approach used by jQuery’s unit tests prior to version 1.6 并且比使用 $(‘.myCheckbox’).removeAttr(‘checked’); 更可取      ,因为如果最初选中该框      ,则后者将在包含它的任何表单上更改对 .reset() 的调用的行为——这是一种微妙但可能不受欢迎的行为改变      。

有关更多上下文                   ,可以在 version 1.6 release notes 和 属性与属性 .prop() documentation 的部分                   。

@Xian 删除选中的属性使得无法重置表单

附带说明一下            ,jQuery 1.6.1 应该解决了我提到的问题      ,所以我们在技术上仍然可以回到使用 $(...).prop(...)

“如果您只使用一个元素                   ,使用 DOMElement.checked = true 总是最快的             ”             。但它可以忽略不计            ,因为它只是一个元素......

正如 Tyler 所说,这是对性能的微不足道的改进      。对我来说                   ,使用通用 API 进行编码比混合原生 API 和 jQuery API 更具可读性                  。我会坚持使用 jQuery             。

@TylerCrompton - 当然                  ,这不完全是关于性能,但做 $(element).prop(checked) 完全是浪费打字。 element.checked 存在并且应该在您已经拥有 element 的情况下使用

解决方案2:

huntsbot.com精选全球7大洲远程工作机会             ,涵盖各领域                  ,帮助想要远程工作的数字游民们能更精准                  、更高效的找到对方                  。

利用:

$(".myCheckbox").attr(checked, true); // Deprecated $(".myCheckbox").prop(checked, true);

如果你想检查一个复选框是否被选中:

$(.myCheckbox).is(:checked);

还检查了 $(selector).checked 来检查

我尝试了这个确切的代码      ,但在需要检查和取消选中所有以及检查它们的状态的全选/全选复选框的情况下             ,它对我不起作用                   。相反                   ,我尝试了@Christopher Harris 的回答      ,就成功了。

为什么使用“form #mycheckbox                  ”而不是简单的“#mycheckbox      ”? id在整个文档中已经是唯一的了      ,直接挑起来更快更简单            。

@YuriAlbuquerque 这是一个例子                   。你可以使用任何你想要的选择器      。

$(selector).checked 不起作用            。 jQuery 中没有“检查             ”方法                   。

解决方案3:

huntsbot.com高效搞钱                   ,一站式跟进超10+任务平台外包需求

这是使用 jQuery 选中和取消选中复选框的正确方法            ,因为它是跨平台标准      ,并且允许表单重新发布      。

$(.myCheckBox).each(function(){ this.checked = true; }); $(.myCheckBox).each(function(){ this.checked = false; });

通过这样做                   ,您将使用 JavaScript 标准来检查和取消选中复选框            ,因此任何正确实现复选框元素的“已选中                   ”属性的浏览器都将完美地运行此代码      。这应该是所有主流浏览器,但我无法在 Internet Explorer 9 之前进行测试                   。

问题(jQuery 1.6):

一旦用户单击一个复选框                   ,该复选框就会停止响应“选中      ”属性更改             。

这是一个在有人单击复选框后复选框属性无法完成工作的示例(这发生在 Chrome 中)      。

Fiddle

解决方案:

通过在 DOM 元素上使用 JavaScript 的“checked      ”属性                  ,我们能够直接解决问题,而不是试图操纵 DOM 来做我们想要它做的事情                  。

Fiddle

此插件将更改 jQuery 选择的任何元素的选中属性             ,并在所有情况下成功选中和取消选中复选框             。因此                  ,虽然这可能看起来像是一个过分的解决方案      ,但它会让您的网站的用户体验更好             ,并有助于防止用户感到沮丧。

(function( $ ) { $.fn.checked = function(value) { if(value === true || value === false) { // Set the value of the checkbox $(this).each(function(){ this.checked = value; }); } else if(value === undefined || value === toggle) { // Toggle the checkbox $(this).each(function(){ this.checked = !this.checked; }); } return this; }; })( jQuery );

或者                   ,如果您不想使用插件      ,可以使用以下代码片段:

// Check $(:checkbox).prop(checked, true); // Un-check $(:checkbox).prop(checked, false); // Toggle $(:checkbox).prop(checked, function (i, value) { return !value; });

在您的第一个 JSFiddle 示例中      ,您应该使用 removeAttr(checked) 而不是 attr(checked, false)

@DanielXMoore                   ,您正在绕过这个问题                  。该示例显示一旦用户单击复选框            ,浏览器将不再响应 checked 属性更改      ,无论用于更改它们的方法                   。

@ChristopherHarris 好的                   ,你说得对            ,我错过了。从 jQuery 1.6 开始,您不应该使用 .prop 方法吗?$(.myCheckBox).prop(checked, true) 这样它将自动应用于整个匹配元素集(尽管只有在设置时                   ,获取仍然只是第一个)

是的            。 prop 绝对是在元素上设置属性的适当方式                   。

@ChristopherHarris                  ,我已经在插件中添加了我需要的东西,以允许一些参数灵活性      。这使得内联处理更容易             ,无需类型转换            。特别是来自不同数据库的“想法                   ”关于“真实            ”是什么                   。小提琴:jsfiddle.net/Cyberjetx/vcp96

解决方案4:

huntsbot.com高效搞钱                  ,一站式跟进超10+任务平台外包需求

你可以做

$(.myCheckbox).attr(checked,true) //Standards compliant

或者

$("form #mycheckbox").attr(checked, true)

如果您在要触发的复选框的 onclick 事件中有自定义代码      ,请改用此代码:

$("#mycheckbox").click();

您可以通过完全删除该属性来取消选中:

$(.myCheckbox).removeAttr(checked)

您可以像这样检查所有复选框:

$(".myCheckbox").each(function(){ $("#mycheckbox").click() });

你也可以去 $("#myTable input:checkbox").each(...);

你也可以去$(".myCheckbox").click()

@Michah 删除选中的属性使得无法重置表单

此答案已过时             ,因为它使用 .attr 而不是 .prop      。

$("#mycheckbox").click(); 为我工作                   ,因为我也在收听更改事件      ,.attr & .prop 没有触发更改事件      。

解决方案5:

huntsbot.com聚合了超过10+全球外包任务平台的外包需求      ,寻找外包任务与机会变的简单与高效                   。

您还可以使用新方法扩展 $.fn 对象:

(function($) { $.fn.extend({ check : function() { return this.filter(":radio, :checkbox").attr("checked", true); }, uncheck : function() { return this.filter(":radio, :checkbox").removeAttr("checked"); } }); }(jQuery));

然后你可以这样做:

$(":checkbox").check(); $(":checkbox").uncheck();

或者                   ,如果您使用其他使用这些名称的库            ,您可能希望给它们提供更多独特的名称      ,例如 mycheck() 和 myuncheck()             。

huntsbot.com洞察每一个产品背后的需求与收益                   ,从而捕获灵感

@livfree75 删除选中的属性使得无法重置表单

此答案已过时            ,因为它使用 .attr 而不是 .prop      。

解决方案6:

一个优秀的自由职业者,应该有对需求敏感和精准需求捕获的能力                   ,而huntsbot.com提供了这个机会

$("#mycheckbox")[0].checked = true; $("#mycheckbox").attr(checked, true); $("#mycheckbox").click();

最后一个将触发复选框的单击事件                  ,其他则不会                  。因此,如果您在要触发的复选框的 onclick 事件中有自定义代码             ,请使用最后一个             。

前一个将失败...检查不是 jquery 对象成员

此答案已过时                  ,因为它使用 .attr 而不是 .prop。

IMO click 事件在 Firefox 和 Edge 中不可靠                  。

解决方案7:

一个优秀的自由职业者      ,应该有对需求敏感和精准需求捕获的能力             ,而huntsbot.com提供了这个机会

要检查一个复选框                   ,您应该使用

$(.myCheckbox).attr(checked,true);

或者

$(.myCheckbox).attr(checked,checked);

并且要取消选中复选框      ,您应该始终将其设置为 false:

$(.myCheckbox).attr(checked,false);

如果你这样做

$(.myCheckbox).removeAttr(checked)

它会一起删除属性      ,因此您将无法重置表单                   。

BAD DEMO jQuery 1.6。我认为这是坏的            。对于 1.6                   ,我将就此发表一篇新文章                   。

NEW WORKING DEMO jQuery 1.5.2 在 Chrome 中工作      。

两个演示都使用

$(#tc).click(function() { if ( $(#myCheckbox).attr(checked)) { $(#myCheckbox).attr(checked, false); } else { $(#myCheckbox).attr(checked, checked); } });

这是不准确的            。将 checked 属性设置为 至少不会取消选中 chrome 中的复选框                   。

@xixonia 我在发布您的小提琴之前进行了测试            ,因为您没有更改左侧的菜单以包含 jquery

mcgralim - 在 1.6 中它更容易.... $(".mycheckbox").prop("checked", true/false)

@MarkAmery 您提到我的帖子在发布时没有添加任何内容      ,但这是准确的      。如果您查看已接受答案的历史记录                   ,您会发现他们建议删除该元素      。这使得无法重置表单            ,这就是我开始发布的原因                   。

@mcgrailm 我已经根据您的评论修改了接受的答案             。如果您想看看它并检查它在当前状态下是否看起来不错,我将不胜感激      。我再次为提出尖锐的批评表示歉意                   ,这些批评至少在一定程度上是高度误导的                  。

解决方案8:

与HuntsBot一起                  ,探索全球自由职业机会–huntsbot.com

这将选择具有指定属性且值包含给定子字符串“ckbItem      ”的元素:

$(input[name *= ckbItem]).prop(checked, true);

它将选择其名称属性中包含 ckbItem 的所有元素             。

解决方案9:

打造属于自己的副业,开启自由职业之旅             ,从huntsbot.com开始!

假设问题是…

如何按值检查复选框集?

请记住                  ,在典型的复选框集中      ,所有输入标签都具有相同的名称             ,它们的不同之处在于属性 value:该集中的每个输入都没有 ID。

Xian 的答案可以使用以下代码行使用更具体的选择器进行扩展:

$("input.myclass[name=myname][value=the_value]").prop("checked", true);

解决方案10:

HuntsBot周刊–不定时分享成功产品案例                   ,学习他们如何成功建立自己的副业–huntsbot.com

我错过了解决方案                  。我会一直使用:

if ($(#myCheckBox:checked).val() !== undefined) { //Checked } else { //Not checked }

这没有回答问题(问题是关于 setting 是否选中了复选框      ,而不是确定是否选中了复选框)                   。这也是确定复选框是否被选中的一种非常丑陋的方式(一方面      ,您正在利用一个不言而喻的事实                   ,即当调用 0 个元素来检测 jQuery 对象时            ,.val() 将始终返回 undefined是空的      ,当您可以简单地检查它的 .length 时)- 请参阅 stackoverflow.com/questions/901712/… 了解更多可读方法。

解决方案11:

huntsbot.com – 程序员副业首选                   ,一站式外包任务      、远程工作             、创意产品分享订阅平台            。

要使用 jQuery 1.6 或更高版本检查复选框            ,只需执行以下操作:

checkbox.prop(checked, true);

要取消选中,请使用:

checkbox.prop(checked, false);

下面是我喜欢使用 jQuery 来切换复选框的方法:

checkbox.prop(checked, !checkbox.prop(checked));

如果您使用的是 jQuery 1.5 或更低版本:

checkbox.attr(checked, true);

要取消选中                   ,请使用:

checkbox.attr(checked, false);

原文链接:https://www.huntsbot.com/qa/XWjE/setting-checked-for-a-checkbox-with-jquery?lang=zh_CN

huntsbot.com汇聚了国内外优秀的初创产品创意                  ,可按收入                   、分类等筛选,希望这些产品与实践经验能给您带来灵感                   。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
inccest(incd.exe进程信息是什么 incd是什么进程) windows11更改用户名文件全部没了(Windows 11系统怎么修改用户名密码? win11更改账户密码的多种方法)