在Ajax - ASP.NET MVC5之后单击它时禁用按钮

时间:2018-04-20 14:31:14

标签: javascript c# asp.net ajax asp.net-mvc-5

我在ASP.NET MVC5中有一个使用FormMethod.Post的表单我有一个提交表单的“创建”按钮,但是如何让它工作,以便点击创建然后它禁用按钮。我试过了:

onclick="this.disabled = true"

但是表单未提交,在删除表单时,只需点击创建

即可添加多条记录

这是我的表格代码:

    @section scripts {
    @Scripts.Render("~/bundles/jqueryajaxval")
    @Scripts.Render("~/bundles/jqueryval")

    <script language="javascript" type="text/javascript">
        // cancel
        $(document).on("click",
            "#CancelForm",
            function(e) {
                var uri = '@Html.Raw(Url.Action("Index", "Membership"))';
                window.location = uri;
                e.preventDefault();
            });

        // submit
        $(document).on("click", "#submitMembership", function(e) {
                // Perform Ajax request to check if CAE/IPI Number is unique.
                var caeipinumber = $('#addMembershipCAEIPINumber').val();
                if (caeipinumber) {
                    $.ajax({
                        url: '@Url.Action("IsCAEIPINumberUnique", "Membership")',
                        data: ({ 'caeipinumber': caeipinumber, 'personaIdToIgnore': null }),
                        type: 'POST',
                        async: false,
                        cache: false,
                        success: function(result) {
                            if (result.toLowerCase() == "false") {
                                // Number is not unique and already exists, so display validation error to the user.
                                e.preventDefault();
                                $('#addMembershipForm').validate().showErrors({ 'CAEIPINumber': 'CAE / IPI Number already exists!' });
                                return false;
                            }
                            return true;
                        },
                        error: function(xhr, status, error) {
                        }
                    });
                }
            });
    </script>
}

@section additionalStyles {

}

@section modal {

}

<article class="row">
    <h1 class="pageTitle artistHeader fw200 mb20 mt10">@ViewBag.Title</h1>

    <div class="col-md-1"></div>
    <div id="createMembership" class="col-md-10 formContainer">
        <div class="panel">
            <div class="panel-heading">
                <span class="panel-title">
                    <i class="glyphicon glyphicon-pencil"></i>&nbsp;Details of New Membership
                </span>
            </div>

            @using (Html.BeginForm("AddMembership", "Membership", FormMethod.Post, new { id = "addMembershipForm", role = "form", @class = "theme-primary form-horizontal" }))
            {
                <fieldset>
                    <legend style="display: none">Add Membership Form</legend>
                    @Html.AntiForgeryToken()
                    @Html.ValidationSummary(true)
                    <div class="panel-body p25 fill bt0 pbn">
                        <div class="form-group">
                            @Html.LabelFor(x => x.MembershipName, new { @class = "control-label col-md-3" })
                            <div class="col-md-8">
                                @Html.TextBoxFor(x => x.MembershipName, new { id = "addMembershipName", @class = "form-control", placeholder = "Enter Membership Name..." })
                                @Html.ValidationMessageFor(x => x.MembershipName, string.Empty, new { @class = "text-danger" })
                            </div>
                        </div>
                        <div class="form-group">
                            @Html.LabelFor(x => x.CAEIPINumber, new { @class = "control-label col-md-3" })
                            <div class="col-md-8">
                                @Html.TextBoxFor(x => x.CAEIPINumber, new { id = "addMembershipCAEIPINumber", @class = "form-control", placeholder = "Enter CAE / IPI Number..." })
                                @Html.ValidationMessageFor(x => x.CAEIPINumber, string.Empty, new { @class = "text-danger" })
                            </div>
                        </div> 
                    </div>
                    <div class="panel-footer">
                        <div class="text-center">
                            <input type="button" class="btn btn-primary" id="CancelForm" value="Cancel" />
                            <input id="submitMembership" type="submit" class="btn btn-primary" value="Create" />
                        </div>
                    </div>
                </fieldset>
            }
        </div>
    </div>
    <div class="col-md-1"></div>
</article>

3 个答案:

答案 0 :(得分:1)

您应该听取表单提交事件,使用的提交输入会触发表单提交事件,当事件被触发时,您可以禁用您单击的按钮。

$("#form1").submit(function (){
   $("#submitbtn").prop ("disabled",true);
   $.ajax({requestprops,success:function(){
             $("#submitbtn").prop ("disabled",false);
    }});
});

答案 1 :(得分:0)

这应该有效:

<script>
function setDisable(id) {
    document.getElementById(id).disabled=true;
};
</script>

 <input id="submitMembership" type="submit" onclick="setDisable(this.id)" class="btn btn-primary" value="Create" />

答案 2 :(得分:0)

首先,我会在点击提交按钮时删除绑定,而是绑定提交事件。

使用以下内容替换提交按钮功能:

$("#addMembershipForm").submit(function (e) {
            var submitButton = $(this).find(':input[type=submit]').prop('disabled', true); // Find and disable the submit button
            // Perform Ajax request to check if CAE/IPI Number is unique.
            var caeipinumber = $('#addMembershipCAEIPINumber').val();
            if (caeipinumber) {
                $.ajax({
                    url: '@Url.Action("IsCAEIPINumberUnique", "Membership")',
                    data: ({ 'caeipinumber': caeipinumber, 'personaIdToIgnore': null }),
                    type: 'POST',
                    async: false,
                    cache: false,
                    success: function(result) {
                        if (result.toLowerCase() == "false") {
                            // Number is not unique and already exists, so display validation error to the user.
                            submitButton.prop('disabled', false); // Enable submit button
                            e.preventDefault(); // Do not submit form
                            $('#addMembershipForm').validate().showErrors({ 'CAEIPINumber': 'CAE / IPI Number already exists!' });
                        }
                    },
                    error: function(xhr, status, error) {
                    }
                });
            }
      });

var submitButton = $(this).find(':input[type=submit]').prop('disabled', true);用于查找然后禁用该按钮。

然后,它会像您在原始问题中一样进行独特的检查。但是,如果返回false,我们将启用提交按钮,以便用户可以重新提交。