Disable asp.net button after click to prevent double clicking
JavascriptJqueryasp.netasp.net AjaxJavascript Problem Overview
I have an ASP.NET button that I need to disable after the user clicks it to prevent double-clicking. Once the submit completes it has to be enabled again. Can anyone help me with this?
Javascript Solutions
Solution 1 - Javascript
Here is a solution that works for the asp.net button object. On the front end, add these attributes to your asp:Button definition:
<asp:Button ... OnClientClick="this.disabled=true;" UseSubmitBehavior="false" />
In the back end, in the click event handler method call, add this code to the end (preferably in a finally block)
myButton.Enabled = true;
Solution 2 - Javascript
I have found this, and it works:
btnSave.Attributes.Add(
"onclick",
"this.disabled = true;" + ClientScript.GetPostBackEventReference(btnSave, null) + ";");
Solution 3 - Javascript
Check this link, the most simplest way and it does not disable the validations.
http://aspsnippets.com/Articles/Disable-Button-before-Page-PostBack-in-ASP.Net.aspx
If you have e.g.
<form id="form1" runat="server">
<asp:Button ID="Button1" runat="server" Text="Button1" OnClick="Button1_Clicked" />
</form>
Then you can use
<script type = "text/javascript">
function DisableButton() {
document.getElementById("<%=Button1.ClientID %>").disabled = true;
}
window.onbeforeunload = DisableButton;
</script>
To disable the button if and after validation has succeeded, just as the page is doing a server postback.
Solution 4 - Javascript
If you want to prevent double clicking due to a slow responding server side code then this works fine:
<asp:Button ... OnClientClick="this.disabled=true;" UseSubmitBehavior="false" />
Try putting a Threading.Thread.Sleep(5000) on the _Click() event on the server and you will see the button is disabled for the time that the server is processing the click event.
No need for server side code to re-enable the button either!
Solution 5 - Javascript
If anyone cares I found this post initially, but I use ASP.NET's build in Validation on the page. The solutions work, but disable the button even if its been validated. You can use this following code in order to make it so it only disables the button if it passes page validation.
<asp:Button ID="Button1" runat="server" onclick="Button1_Click" Text="Submit" OnClientClick=" if ( Page_ClientValidate() ) { this.value='Submitting..'; this.disabled=true; }" UseSubmitBehavior="false" />
Solution 6 - Javascript
Just need to add 2 attributes for asp button :
OnClientClick="this.disabled='true';" UseSubmitBehavior="false"
e.g.
<asp:Button ID="Button1" runat="server" Text="TEST" OnClientClick="this.disabled='true';" UseSubmitBehavior="false" CssClass="button-content btnwidth" OnClick="ServerSideMethod_Click" />
For more details:
https://bytes.com/topic/asp-net/answers/918280-disable-button-click-prevent-multiple-postbacks
Solution 7 - Javascript
<asp:Button ID="btnSend" runat="server" Text="Submit" OnClick="Button_Click"/>
<script type = "text/javascript">
function DisableButton()
{
document.getElementById("<%=btnSend.ClientID %>").disabled = true;
}
window.onbeforeunload = DisableButton;
</script>
Solution 8 - Javascript
You can use the client-side onclick event to do that:
yourButton.Attributes.Add("onclick", "this.disabled=true;");
Solution 9 - Javascript
Disable the button on the OnClick event, then re-enable on the AJAX callback event handler. Here is how I do it with jQuery.
<script>
$(document).ready(function() {
$('#buttonId').click(function() {
$(this).attr('disabled', 'disabled');
callAjax();
});
});
function callAjax()
{
$.ajax({
url: 'ajax/test.html',
success: function(data) {
//enable button
$('#buttonId').removeAttr('disabled');
}
});
}
</script>
Solution 10 - Javascript
I like to disable the button and call a postback, this way the code behind still gets run after the button is disabled.
this is how i attach from code behind:
btnProcess.Attributes.Add("onclick", " this.disabled = true; __doPostBack('btnProcess', ''); return false;")
Then re-enable the button in code behind:
btnProcess.Enabled = True
Solution 11 - Javascript
using jQuery:
$('form').submit(function(){
$(':submit', this).click(function() {
return false;
});
});
Solution 12 - Javascript
Try this, it worked for me
<asp:Button ID="button" runat="server" CssClass="normalButton"
Text="Button" OnClick="Button_Click" ClientIDMode="Static"
OnClientClick="this.disabled = true; setTimeout('enableButton()', 1500);"
UseSubmitBehavior="False"/>
Then
<script type="text/javascript">
function enableButton() {
document.getElementById('button').disabled = false;
}
</script>
You can adjust the delay time in "setTimeout"
Solution 13 - Javascript
This solution works if you are using asp.net validators:
<script language="javascript" type="text/javascript">
function disableButton(sender,group)
{
Page_ClientValidate(group);
if (Page_IsValid)
{
sender.disabled = "disabled";
__doPostBack(sender.name, '');
}
}</script>
and change the button:
<asp:Button runat="server" ID="btnSendMessage" Text="Send" OnClick="btnSendMessage_OnClick" OnClientClick="disableButton(this,'theValidationGroup')" CausesValidation="true" ValidationGroup="theValidationGroup" />
Solution 14 - Javascript
You can do this with javascript. in your form
tag, onsubmit="javascript:this.getElementById("submitButton").disabled='true';"
Solution 15 - Javascript
This works with a regular html button.
<input id="Button1"
onclick="this.disabled='true';" type="button"
value="Submit" name="Button1"
runat="server" onserverclick="Button1_Click">
The button is disabled until the postback is finished, preventing double clicking.
Solution 16 - Javascript
<script type = "text/javascript">
function DisableButtons() {
var inputs = document.getElementsByTagName("INPUT");
for (var i in inputs) {
if (inputs[i].type == "button" || inputs[i].type == "submit") {
inputs[i].disabled = true;
}
}
}
window.onbeforeunload = DisableButtons;
</script>