首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >$('.input:checked')的行为不同于$('.input[checked=checked]')

$('.input:checked')的行为不同于$('.input[checked=checked]')
EN

Stack Overflow用户
提问于 2014-09-09 17:50:34
回答 2查看 81关注 0票数 1

以下面的场景为例:您有两个单选按钮,都具有相同的名称,并且都选中了(我知道这是无效的):

代码语言:javascript
复制
<input type="radio" class="input" name="cb1" checked="checked" />
<input type="radio" class="input" name="cb1" checked="checked" />

为什么以下两个选择器的行为不同?

代码语言:javascript
复制
$('.input:checked').size(); // returns 1
$('.input[checked=checked]').size(); // returns 2

显然,第一个选择器只返回标记中最后出现的复选框,而第一个选择器则返回两者。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-09-09 17:55:05

这是因为:checked选择器检查元素 checked属性。

票数 4
EN

Stack Overflow用户

发布于 2014-09-09 18:02:59

由于两个元素具有相同的名称,因此它们作为一个单元运行,在呈现元素时实际上只选择了一个单选按钮。

.input[checked=checked]不关心结果,它只检查属性。

.input:checked反映了实际的元素状态。

name更改为不同,这两个查询都将返回2

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25750908

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档