I have a C# .Net web app. In that app I need to conditionally disable Html.TextBoxFor
controls (also Html.DropDownListFor
controls) based on who is logged into the system. I tried using
@Html.TextBoxFor(model => model.ProposalName, new { @ViewBag.IsDisabled })
Where @ViewBag.IsDisabled
is set to either String.Empty or "disabled" in the Controller. However, this renders as IsDisabled='disabled'
or IsDisabled=""
so the control is not disabled. When I tried
@Html.TextBoxFor(model => model.ProposalName, new { @ViewBag.Disabled })
The control was always disabled even if ViewBag.Disabled
contained no text. How can I conditionally disable the Html.TextBoxFor()
controls?
Try
The solution posted by @epignosisx works, but it may be a problem if you want to add some other attribute because you will have to add it it both objects (the one with
disabled
and the one now its empty).Even worse if you have some other bool property because you will have four different objects, each one for each combination.
The best solution here (with a little more code) is to build an extension method for HtmlHelper to receive your boolean property as a parameter.
Here there is another example
Extending @James's answer, I wrote this HtmlHelper extension that updates/removes the
disabled
attribute if it's already present, or adds it if not:It also plays nicely with self-closing tags (like
<input />
).Usage is the same:
Tested on both
@Html.DropDownListFor()
and@Html.TextBoxFor()
.I had this same problem and decided to write my own
HtmlHelper
extension method.This will accept a boolean to indicate if the control should be disabled or not. It just appends
disabled="disabled"
just inside the first>
it comes across in a string.You can use it like below.
@Html.TextBoxFor(model => model.ProposalName).Disable(true)
Here is the method I use, which doesn't require extensions, and doesn't limit you to only one HTML attribute. It assumes there is a boolean property named "Disabled" in your model, but you could put whatever you wanted in there, as long as it evaluates to boolean for the ternary operator:
The limitation with the standard shortcut notation is that the name of the attribute cannot be dynamic. By creating a dictionary of the correct type, you can then make the attribute name dynamic, and you then pass that dictionary to the textbox as the dictionary of attributes. When the field is not to be disabled, it passes an attribute named "data-notdisabled" instead of one named "disabled", which the browser will then ignore.