jQuery:如何只选择可见和检查的复选框?

时间:2013-05-20 08:40:20

标签: jquery

我正在尝试检查特定系列中的所有可见复选框是否都已经过检查,我想只计算那些可见的和那些可见的并检查以查看数字是否相同。问题是我无法使可见或选中的选择器工作。

这些是我的一些想法,但没有奏效:

if($j("input[id^='chk_camp']:visible:checked").length == $j("input[id^='chk_camp']:visible").length)

在这种情况下,双方都是0

if($j("input[id^='chk_camp']").filter(':visible').filter(':checked').length == $j("input[id^='chk_camp']").filter(':visible').length)

双方也返回0。

也试过

if($j("input[id^='chk_camp'][visible][checked]").length == $j("input[id^='chk_camp'][visible]").length)

这也是双方都返回0。

注释$j("input[id^='chk_camp']").length会返回正确的值。我正在使用的浏览器是Firefox。

我在这里做错了什么?

答案:显然,我做错了就是其他地方。在实际制作包含复选框的div之前,我正在进行这些检查,因此所有可见性检查都返回false。

3 个答案:

答案 0 :(得分:7)

你可以这样做:

<强> jsfiddle

jQuery的:

$('input').each(function() {

    // If input is visible and checked...
    if ( $(this).is(':visible') && $(this).prop('checked') ) {

        $(this).wrap('<div />');

    }

});

HTML:

<input type="checkbox" checked="checked">
<input type="checkbox" checked="checked" style="display: none;">
<input type="checkbox">
<input type="checkbox" checked="checked" style="display: none;">
<input type="checkbox" checked="checked">
<input type="checkbox">

CSS:

div { float: left; background: green; }
div input { display: block !important; }

答案 1 :(得分:6)

这对我来说很好。

$(".inputClass:checked:visible");
$(".inputClass:checked:visible").length;

或调整上述答案。

<强> jsfiddle

$('input:visible:checked').each(function() {
    $(this).wrap('<div />');
});

答案 2 :(得分:2)

这是不正确的:

if($j("input[id^='chk_camp']").filter(':visible').filter(':checked).length == $j("input[id^='chk_camp']).filter(':visible').length)
//                                                          ------^------ missing qoutes here      ----^--- also double quotes here