繁体   English   中英

如何以编程方式取消选中已选中的复选框?

[英]How can I uncheck a checked checkbox programmatically?

说我有以下样本:

<input name="Opt1" id="Opt1" type="checkbox" value="1" alt="1948" title="RQlevel1" src="2" checked="checked" onclick="levels();"/>  <label style="cursor:pointer" for="OptID12851948">PADI Advanced Open Water</label>

<input name="Opt2" id="Opt2" type="checkbox" value="2" alt="1953" title="RQlevel2" src=""  onclick="levels();"/>  <label style="cursor:pointer" for="OptID19521953">PADI Rescue</label>

<input name="Opt3" id="Opt3" type="checkbox" value="3" alt="1957" title="RQlevel2" src=""  onclick="levels();"/>  <label style="cursor:pointer" for="OptID19521953">PADI Rescue2</label>

如果我单击PADI Advanced Open Water复选框,然后调用levels()JavaScript函数,如何使用jQuery以编程方式取消选中此复选框?

我尝试了以下但不起作用:

if ($("input[value='1']:checked").attr("checked")){
    $("input[value='1']:checked").attr(“checked”, false);
}   

使用removeAttr

$("input[value='1']:checked").removeAttr('checked');

或者使用最新版本的jQuery,您可以使用prop

$("input[value='1']:checked").prop('checked', false);

如果你使用jQuery 1.6及以上,你应该真的使用.prop()

此外,您的选择器已确定已选中输入。 没有必要通过检查属性或属性来复制它。

if ($("input[value='1']:checked").length) { 
    $("input[value='1']:checked").prop("checked", false); 
}    

但是,如果您使用的jQuery版本低于1.6,则可以使用removeAttr()。

if ($("input[value='1']:checked").length) { 
    $("input[value='1']:checked").removeAttr("checked"); 
}    

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM