javascript - 带有隐藏输入的自定义复选框未正确选择。 Javascript 需要调整

标签 javascript css checkbox

我正在使用自定义复选框,其中 input 隐藏在 span 中;我已经编写了一个脚本来为 checked 添加类,但它实际上并没有将输入标记为已检查。我在这里做错了什么?

更新:现在检查复选框!万岁。一个新问题是隐藏复选框的可见性,在复选框区域选中时也会隐藏新类...如果单击标签,则复选框显示为已选中,但如果单击复选框图像本身,什么都没有改变...

HTML

<fieldset>
  <label class="sublabel" title="Insights & Planning" for="checkbox-insights-and-planning">Insights & Planning</label>

  <span class="open-checkbox">
     <input id="checkbox-insights-and-planning" class="key-areas-checkbox" name="key-areas-of-interest" type="checkbox" />
  </span>
</fieldset>

CSS

.open-checkbox {
    background-position: -4px -48px;
    background-image: url(../images/adcolor-sprite.png);
    background-repeat: no-repeat;
    cursor: pointer;
    display: block;
    float: right;
    height: 25px;
    margin-top: 10px;
    width: 25px;
}

.checked {
    background-position: -4px -12px;
    background-image: url(../images/adcolor-sprite.png);
    background-repeat: no-repeat;
    cursor: pointer;
    display: block;
    float: right;
    height: 25px;
    margin-top: 10px;
    width: 25px;
}

input[type=checkbox] {
    visibility: hidden;
}

#key-areas-inputs label.sublabel {
    display: block;
    float: left;
    height: 44px;
    padding: 0 0 0 10px;
    width: 300px;
}
#key-areas-inputs input.key-areas-checkbox {
    float: right;
    display: block;
    clear: none;
    height: 22px;
    width: 22px;
    margin-top: 18px;
    margin-right: 4px;
    margin-bottom: 0px;
    margin-left: 0px;
}
#key-areas-label {
    font-family: "Futura W01 Bold", Arial, Helvetica, sans-serif;
    font-size: 16px;
    color: #df007c;
    display: block;
    clear: left;
    float: left;
    width: 348px;
    margin-top: 50px;
    margin-right: 0px;
    margin-bottom: 0px;
    margin-left: 0px;
    padding-top: 0px;
    padding-right: 30px;
    padding-bottom: 0px;
    padding-left: 0px;
    text-align: right;
}

JS

// check checked boxes on load     
    $(".key-areas-checkbox:checked").each(function(){
        $(this).next().addClass('checked');
    });

    // add class and checked attribute to filter inputs
    $('.open-checkbox').click(function () {
        console.log('click');
        var $this = $(this);
        var $input = $this.find('input');

        $this.toggleClass('checked', $input.is(':checked'));
        return;

        if($input.prop('checked')){
            $this.removeClass('checked');
        } else {
            $this.addClass('checked');
        }
    });

最佳答案

检查复选框添加:

 $input.attr('checked','checked');

取消勾选:

$input.removeAttr('checked');

关于javascript - 带有隐藏输入的自定义复选框未正确选择。 Javascript 需要调整,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18834624/

相关文章:

javascript - 为什么全局范围内的变量被分配给 window 对象?

javascript - 使用 Angular $resource 自动保存

javascript - 按容器更改字体大小

javascript - Jquery 同位素复选框过滤

javascript - 从 jquery 创建链接

javascript - jQuery 通过元素旋转类

html - 使用 CSS 将 <div> 左对齐到居中的 <div>

jquery - Bootstrap 移动导航栏在加载时打开并且不会切换

javascript - CSS 复选框样式不起作用

jquery - 如果输入类型复选框的值已选中 ="checked",则显示/隐藏特定的 div