繁体   English   中英

复选框未在视觉上取消选中

[英]Checkbox not unchecking visually

我有一个表格,其中包括:

<fieldset class="billing-address">
    <legend>Billing Address</legend>
  <ol>
        <li class="text combi"><label for="bill-address1">Address:</label> <input size="20" value="" name="basket_order:default:bill_address1" id="bill-address1"></li>
        <li class="text"><label for="bill-address2">Address:</label> <input size="20" value="" name="basket_order:default:bill_address2" id="bill-address2"></li>
        <li class="text"><label for="bill-address3">Town/City:</label> <input size="20" value="" name="basket_order:default:bill_address3" id="bill-address3"></li>
        <li class="text"><label for="bill-address4">Region:</label> <input size="20" value="" name="basket_order:default:bill_address4" id="bill-address4"></li>
        <li class="text"><label for="bill-post-code">Post code:</label> <input size="10" value="" name="basket_order:default:bill_postcode" id="bill-post-code"></li>
    </ol>
</fieldset>

由于太过于难以进入这里的原因,我无法直接获取HTML并需要通过javascript进行操作。 所以,我使用以下内容添加一个复选框和标签:

$('.billing-address ol').before('<input type="checkbox" id="billing-add-different" /><label for="billing-add-different">My billing address is the same as my delivery address</label>');

    $('#billing-add-different').prop('checked',true).toggle(
        function(){
          $('.billing-address ol input, .billing-address ol select').css('background','#CCC').attr('disabled','disabled');
        },
        function(){
          $('.billing-address ol input, .billing-address ol select').css('background','#FFF').removeAttr('disabled');
        }
      );

这会切换“禁用”属性和背景颜色,具体取决于是否勾选。

但是,虽然该功能正在触发,但仍会以可视方式检查该复选框。

我在http://jsfiddle.net/EFQuh/做了一个jsfiddle来说明。 该错误发生在Firefox 8.0中,不确定其他错误。

我不知道问题出在哪里(可能是toggle功能),但是您可以将代码简化为:

$('#billing-add-different').prop('checked',true).change(function(){
    $('.billing-address ol input, .billing-address ol select')
        .css('background-color', this.checked ? '#CCC' : '#FFF')
        .prop('disabled',this.checked);

}).change();

DEMO

您需要使用change事件并在事件功能内选中this.checked

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM