7

查询:

<script type="text/javascript">

function  enableDisableButton() {

    var isChecked = ($('input[name=ignore-checkbox]').is(':checked'));

    if (isChecked == true) {
        $("button[name=set-up-account]").removeAttr("disabled");
    }
    else {
        $("button[name=set-up-account]").attr("disabled", "disabled");
    }

}

$('#mobilePage').live('pageinit', function (event) {    //document ready for jquery mobile

    enableDisableButton();

    $('#ignore-checkbox').bind("change", function () {
        enableDisableButton();
    });

});
  </script>

html:

 @using (Html.BeginForm("Account", "SetUpAccount", FormMethod.Post, new { @id = "account-set-up", @data_ajax = "false" }))
 {       

     <div class="ui-grid-a field">
        <div class="ui-block-a" style="width:140px;">
         <label for="ignore-checkbox">Ignore</label>
         <input type="checkbox" name="ignore-checkbox" id="ignore-checkbox"/>
        </div>
     </div>

     <div style="width:100%;float:left;">
         <button type="submit" name="set-up-account" id="set-up-account"  data-inline="true"  data-mini="true">Set Up Account</button>
     </div>
  }

我想Set Up Account根据复选框选中的属性启用/禁用按钮。如果选中复选框,则启用按钮,否则禁用。在页面加载时,我正在禁用按钮

我面临的问题是,

在页面加载时,它禁用了按钮,但它没有根据复选框的更改事件添加/删除禁用的属性,我签入了 firebug,它根据选中和未选中的值正确进入循环。

注意:我使用的是 Jquery mobile 1.2 和 jquery 1.7。同样,在此处发布之前,我在 google 中进行了搜索,根据复选框选中的值启用和禁用按钮下有许多帖子。但没有一个能解决我的问题。

有什么问题?请帮我

谢谢...

4

4 回答 4

42

我不确定这是否有助于解决您的主要问题,但根据http://api.jquery.com/prop/您应该使用 .prop() 函数而不是 .attr 添加和删除禁用的属性() 和 .removeAttr() 函数。

要添加属性:

.prop("disabled", true);

要删除该属性:

.prop("disabled", false);

我在寻找上述信息时偶然发现了这个问题,所以我想我会分享。

于 2014-11-14T00:45:49.447 回答
7

由于 Jquery Mobile,它没有启用按钮。在 JQM 中,我们需要刷新表单元素,同时对其进行操作

解决方案是

    function  enableDisableButton() {

    var isChecked = ($('input[name=ignore-checkbox]').is(':checked'));

    if (isChecked) {
        $("button[name='set-up-account']").removeAttr("disabled").button('refresh');
    }
    else {
        $("button[name='set-up-account']").attr("disabled", "disabled").button('refresh');
   }
}

$('#mobilePage').live('pageinit', function (event) {

    enableDisableButton();

    $('#ignore-checkbox').bind("change", function () {
        enableDisableButton();
    });
});

问题已通过添加解决

.button('refresh');
于 2012-11-07T10:46:52.107 回答
7

像这个

  $('#setagb').change(function(){
        if ($(this).is(':checked'))
        {
            $("#submit").removeAttr("disabled");
        }
        else
        {
            $("#submit").attr( "disabled", "disabled" );
        }               
  });
于 2013-09-25T13:45:57.573 回答
0

试试这个

$("input[name=ignore-checkbox]").click(function() {
  $("button[name=set-up-account]").attr("disabled", this.checked);
});

演示

于 2012-11-07T09:31:30.887 回答