I have an controller which has check like that
if (form["submit"].ToString() == "Continue")
{
}
and i have button which is doing submit
<button name="submit" value="Continue">Continue</button>
It was all working well until i decided to disable Continue button on submit to prevent double click using this function:
$('form').submit(function () {
if ($(this).valid()) {
$(':submit', this).attr('disabled', 'disabled');
}
});
So now i don’t get value form["submit"] posted on controller.
Any thoughts how may i fix that?
I want still prevent second click but be able to get form["submit"] value posted on controller.
Can you control the
submitvalue in a hidden field in the form? I can’t tell what other logic you might need, but when the form renders, you could set the hidden field’s value to the submit button’s value and change it when necessary using the first script below. As long as it has anameattribute and is enabled (which you’d rarely disable a hidden field) then it will post when the form is submitted.And of course in your form, you would need a hidden field with name=”submit”
Then, whenever the state of your form changes, modify the disabled state of the button and the value of the hidden field to reflect the value (if it changed at all).
There are also frameworks you may find useful for UI features like this. KnockoutJS comes to mind. It can be used to “value” bind input elements. It’s probably overkill for this small example, but it could be useful if your UI expands. I’ve added markup, script and comments below if you’re interested.
KnockoutJS requires you use the
data-bindattribute to setup your elements. In your case, you’d bind one property to multiple elements like this: