html input check属性,关于HTML中input标签(radio|checkbox)的checked属性 property attribute

这篇博客探讨了在HTML中使用jQuery操作radio和checkbox的checked属性时遇到的问题及解决方案。作者指出,使用`.attr()`方法无法正确设置checked状态,而应该使用`.prop()`方法。博客还提到了attribute与property的区别,并建议读者查看相关译文以深入理解。最后,通过Chrome开发者工具的示例进一步说明了这一点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

title: 关于HTML中input标签(radio|checkbox)的checked属性

icon: fa-html5

date: 2017-11-23 18:03:47

categories:

tags: html

jQuery操作checked

如果你在开发中需要用jQuery操作单选(radio)或者多选(checkbox)元素的选中与取消选中,那你可能会遇到这样的问题:

假设有这样的一个checkbox:

你要用jQuery改变他的选中状态,你可能会这样子写:

$("#id").attr("checked", "true");

然而你会发现并没有实现期望,经过简单的百度,会有很多文章告诉你用下面的方法:

$("#id").prop("checked", "true");

然后就成功了。我就是这样过来的。

然后我去看了二者的区别(用谷歌翻译这两句话你会很无助):jquery官网地址

.attr()

Get the value of an attribute for the first element in the set of matched elements or set one or more attributes for every matched element.

.prop()

Get the value of a property for the first element in the set of matched elements or set one or more properties for every matched element.

关于attribute和property

写这篇文章的时候看到一篇译文,讲的正好是他们的区别:传送门,可以去看看,还比较仔细。

总结一下就是:

attribute(特性)是HTML标签上的。

attribute(特性)需要通过getAttribute|setAttribute方法操作。比如常见的class操作,不能ele.class出来的。

property(属性)属于DOM对象。

property(属性)类似JS的对象,可以直接.或者[xxx]操作。

其实对于这些不清晰的我,打开chrome控制台看了一下就明白了:

20408d98a8b0

input20171123.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值