Условный атрибут Html.TextBox с ASP.NET MVC Preview 5
У меня есть строго типизированный MVC View Control, который отвечает за пользовательский интерфейс, где пользователи могут создавать и редактировать элементы клиента. Я бы хотел, чтобы они могли определять ClientId
при создании, но не редактировать, и это должно отображаться в пользовательском интерфейсе.
С этой целью у меня есть следующая строка:
<%= Html.TextBox("Client.ClientId", ViewData.Model.ClientId, new
{ @readonly =
(ViewData.Model.ClientId != null && ViewData.Model.ClientId.Length > 0
? "readonly" : "false")
} )
%>
Кажется, что независимо от того, какое значение я даю атрибуту readonly (даже "false" и ""), Firefox и IE7 делают вход только для чтения, что является досадным контр-интуитивным. Есть ли хороший, основанный на тройной основе способ полностью отбросить атрибут, если он не требуется?
Ответы
Ответ 1
Жесткая проблема... Однако, если вы хотите определить только атрибут readonly
, вы можете сделать это следующим образом:
<%= Html.TextBox("Client.ClientId", ViewData.Model.ClientId,
ViewData.Model.ClientId != null && ViewData.Model.ClientId.Length > 0
? new { @readonly = "readonly" }
: null)
%>
Если вы хотите определить больше атрибутов, вы должны определить два анонимных типа и иметь несколько копий атрибутов. Например, что-то вроде этого (чего мне все равно не нравится):
ClientId.Length > 0
? (object)new { @readonly = "readonly", @class = "myCSS" }
: (object)new { @class = "myCSS" }
Ответ 2
Если вы хотите определить несколько атрибутов и условно readonly , не дублируя другие атрибуты,
вы можете использовать словарь вместо анонимных типов для атрибутов.
например.
Dictionary<string, object> htmlAttributes = new Dictionary<string, object>();
htmlAttributes.Add("class", "myCSS");
htmlAttributes.Add("data-attr1", "val1");
htmlAttributes.Add("data-attr2", "val2");
if (Model.LoggedInData.IsAdmin == false)
{
htmlAttributes.Add("readonly", "readonly");
}
@:User: @Html.TextBoxFor(
m => m.User,
htmlAttributes)
Ответ 3
И альтернатива - просто выпустить его как простой старый HTML. Да, редактор заставит вас думать, что вы ошибаетесь, но это часто случается с VS2008SP1. Этот пример специально предназначен для флажков, которые, кажется, полностью потеряны в CTP5, но дает вам представление о том, как испускать условные атрибуты.
<input type="checkbox" name="roles" value='<%# Eval("Name") %>'
<%# ((bool) Eval("InRole")) ? "checked" : "" %>
<%# ViewData.Model.IsInRole("Admin") ? "" : "disabled" %> />
Ответ 4
Совет. Это простое наличие атрибута readonly/disabled, который делает элемент readonly или отключен в браузере.
@Html.TextBoxFor(x => x.Name, isReadonly ?(object) new { @readonly = true } : new { /*Some other attributes*/ })
Ответ 5
Я думаю, что это должно быть
<%= ((bool) Eval("InRole")) ? "checked" : "" %>
вместо этого в ответах leppies.
<%# ((bool) Eval("InRole")) ? "checked" : "" %>
По крайней мере, это не сработало для меня С#, но это сработало с =. Я сделал что-то неправильно? Спасибо за отзыв в любом случае:)
Ответ 6
$ (функция() { $( "[Только для чтения = 'ложь']" ) removeAttr ( "ReadOnly" ).
});
Ответ 7
i использую это:
@Html.TextAreaFor(model => model.ComentarioGestor, comentarioGestor? new { @class = "form-control" } : new { @class = "form-control", @readonly = "readonly" } as object)
Ответ 8
Я пробовал большинство предложений выше, и теперь я пришел к самому простому с одной строкой. Комбинируйте 2 анонимных объекта атрибутов html, объявив их одним из них как "объект".
@Html.TextBoxFor(m => m.Email, !isEdit ? new { id = "email_box" } : new { id = "email_box", @readonly = isEdit ? "readonly" : "false" } as object)