位置: IT常识 - 正文

使用 jQuery 为复选框设置“选中”(jqueryfor)

编辑:rootadmin
使用 jQuery 为复选框设置“选中” 问题描述:

推荐整理分享使用 jQuery 为复选框设置“选中”(jqueryfor),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery设置复选框选中,jquery 赋值 input,jquery如何赋值,jquery给复选框赋值,jquery如何赋值,jquery 赋值 input,jquery实现复制功能,jquery操作复选框,内容如对您有帮助,希望把文章链接给更多的朋友!

我想做这样的事情来使用 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();使用 jQuery 为复选框设置“选中”(jqueryfor)

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

$('.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汇聚了国内外优秀的初创产品创意,可按收入、分类等筛选,希望这些产品与实践经验能给您带来灵感。

本文链接地址:https://www.jiuchutong.com/zhishi/298819.html 转载请保留说明!

上一篇:前端开发:颜色代码速查表【英文颜色、HEX(十六进制)格式、RGB格式、十进制】(前端好看的颜色)

下一篇:JavaScript之Ajax-axios表单提交

  • 打印健康码需要彩印吗(打印健康码需要彩色打印吗)

    打印健康码需要彩印吗(打印健康码需要彩色打印吗)

  • 华为桌面锁定怎么解除(华为桌面锁定怎么设置)

    华为桌面锁定怎么解除(华为桌面锁定怎么设置)

  • 三星手机回收站在哪里打开(三星手机回收站怎么找到)

    三星手机回收站在哪里打开(三星手机回收站怎么找到)

  • 滴滴出租车输错金额怎么改(滴滴出租车输错金额乘客怎么追回多余的钱)

    滴滴出租车输错金额怎么改(滴滴出租车输错金额乘客怎么追回多余的钱)

  • 通话中怎么输入字母(在通话中怎么输入字母)

    通话中怎么输入字母(在通话中怎么输入字母)

  • vivo手机响铃但没有通话界面(vivo手机铃声响一声就不响了)

    vivo手机响铃但没有通话界面(vivo手机铃声响一声就不响了)

  • 华为p40pro卡怎么装(华为p40pro卡怎么回事)

    华为p40pro卡怎么装(华为p40pro卡怎么回事)

  • 电话闪退怎么回事(电话界面闪退)

    电话闪退怎么回事(电话界面闪退)

  • nex3s什么时候上市(nex3啥时候发布的)

    nex3s什么时候上市(nex3啥时候发布的)

  • 0xc0000428怎么修复(0xc0000034简单修复方法)

    0xc0000428怎么修复(0xc0000034简单修复方法)

  • 怎么发群消息给所有人(怎样发群聊信息给别人)

    怎么发群消息给所有人(怎样发群聊信息给别人)

  • 魅族pop一代和二代的区别(魅族pop和pop2)

    魅族pop一代和二代的区别(魅族pop和pop2)

  • 红包退回对方显示什么(红包被退回对方能看到金额吗)

    红包退回对方显示什么(红包被退回对方能看到金额吗)

  • oppo手机老是黑屏死机怎么办(oppo手机老是黑屏一闪一闪)

    oppo手机老是黑屏死机怎么办(oppo手机老是黑屏一闪一闪)

  • u盘无法访问怎么解决(u盘无法访问怎么解决 文件或目录损坏且无法读取)

    u盘无法访问怎么解决(u盘无法访问怎么解决 文件或目录损坏且无法读取)

  • 监控器1080p和3mp的区别(监控器1080p和5mp分辨率哪个清晰)

    监控器1080p和3mp的区别(监控器1080p和5mp分辨率哪个清晰)

  • 淘宝店被投诉盗图了咋办(淘宝店铺被投诉盗用图片需要申诉吗)

    淘宝店被投诉盗图了咋办(淘宝店铺被投诉盗用图片需要申诉吗)

  • blnal30是全网通么(blnal30是什么机型)

    blnal30是全网通么(blnal30是什么机型)

  • 手机安装包可以删除吗(手机安装包可以全部删除吗)

    手机安装包可以删除吗(手机安装包可以全部删除吗)

  • 小米m1901f9e什么型号(小米m1901f7be)

    小米m1901f9e什么型号(小米m1901f7be)

  • qq黄钻隐身访问会被对方知道吗(QQ黄钻隐身访问对方访客量增加吗)

    qq黄钻隐身访问会被对方知道吗(QQ黄钻隐身访问对方访客量增加吗)

  • 路由器的用户名和密码是什么(路由器的用户名是无线网名称吗?)

    路由器的用户名和密码是什么(路由器的用户名是无线网名称吗?)

  • IE的增强安全设置(ie增强的安全配置已启用上不了网)

    IE的增强安全设置(ie增强的安全配置已启用上不了网)

  • VUE3 中实现拖拽和缩放自定义看板 vue-grid-layout(vue 拖拽到目标区域)

    VUE3 中实现拖拽和缩放自定义看板 vue-grid-layout(vue 拖拽到目标区域)

  • vue 项目兼容 IE 浏览器(vue项目兼容ie9以上浏览器)

    vue 项目兼容 IE 浏览器(vue项目兼容ie9以上浏览器)

  • 【小程序从0到1】小程序常用组件一览(小程序从入门到精通)

    【小程序从0到1】小程序常用组件一览(小程序从入门到精通)

  • 个人所得税应纳税额怎么计算
  • 二手车过户需要带什么资料
  • 化妆品销售公司简介
  • 公司注销后账本怎么处理
  • 固定资产一次性折旧政策2023
  • 汽车销售和租赁哪个大
  • 公司投资款需要纳税吗
  • 车船税不交怎么办
  • 广告费和业务宣传费15%还是30%
  • 金融资产摊余成本例题
  • 管道运输是什么和什么合二为一
  • 航空运单可以作为提货凭证吗
  • 按价格从价缴纳增值税
  • 变更注册资本的股东会决议范本
  • 营改增后自建厂房抵扣
  • 应收帐款从工资里扣税吗
  • 在建工程转固定资产的条件
  • 写字楼出租流程
  • 图书发票没有明细能报销吗?
  • 税控盘抵增值税表怎么填
  • 6月份税务新政热点问题有哪些?
  • 发票拍照打印出来不清晰
  • 生活补贴和节日补贴区别
  • 买车的发票可以抵扣吗?
  • 固定资产可以一次折旧完吗
  • 应收账款怎么登账
  • 微软输入法打不出汉字
  • 增值税专用发票有几联?
  • 企业租赁汽车交什么税
  • 进程cmd.exe
  • PHP:session_decode()的用法_Session函数
  • 资产减值损失的科目编码
  • 发票交付在哪里
  • php对象的概念
  • 职工报销医药费属于什么会计科目
  • php引用类型
  • 进项抵销项的会计分录
  • phpcms怎么样
  • 企业购进商品支付货款时,实际发生现金折扣,应计入
  • python的shell怎么运行文件
  • 业务招待费进项税额转出会计分录
  • 专用发票跨月冲红流程
  • 其他应付款辅助是供应商还是客户
  • sql语句求中位数
  • 企业内部交易如何操作
  • mysql主从配置详解
  • 小规模纳税人出售使用过固定资产
  • 固定资产的核算内容包括
  • 三包适用范围
  • 退休职工取暖费发放标准2023年
  • 佣金付给别人公司合法吗
  • 财政补助结转余额在借方还是贷方
  • 微软9月22
  • windows不兼容
  • Win10预览版更新弹窗如何关闭
  • window10总更新是怎么回事
  • windows vista可以换7吗
  • windows无法
  • windows8怎么调整亮度
  • win10预览版bug
  • Win10 Mobile 10581预览版升级界面曝光 上手视频观赏
  • spmgr.exe - spmgr是什么进程 有什么用
  • Win10如何打开软键盘
  • win10 20h2怎么更新
  • windos10正式版
  • win10 edge浏览器崩溃
  • linux网络中断
  • jquery实现搜索功能
  • jquery实现手风琴遇到问题
  • unity5.x游戏开发指南
  • javascript中的函数也称为什么
  • 修改文件名ren
  • pm2启动nodejs
  • yarn功能
  • 爱山东怎样查询医保余额
  • 开票盘注销后能否撤回
  • 税控盘打印机设置参数
  • 混凝土税率是多少2021
  • 拟录用是正式录用吗
  • 受让企业与转让企业区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设