O problema é que seu modelo pode conter vários elementos HTML, então MVC não saberá a qual deles aplicar seu tamanho / classe. Você terá que definir você mesmo.
Faça seu modelo derivar de sua própria classe chamada TextBoxViewModel:
public class TextBoxViewModel
{
public string Value { get; set; }
IDictionary<string, object> moreAttributes;
public TextBoxViewModel(string value, IDictionary<string, object> moreAttributes)
{
// set class properties here
}
public string GetAttributesString()
{
return string.Join(" ", moreAttributes.Select(x => x.Key + "='" + x.Value + "'").ToArray()); // don't forget to encode
}
}
No modelo, você pode fazer isso:
<input value="<%= Model.Value %>" <%= Model.GetAttributesString() %> />
Em sua opinião, você:
<%= Html.EditorFor(x => x.StringValue) %>
or
<%= Html.EditorFor(x => new TextBoxViewModel(x.StringValue, new IDictionary<string, object> { {'class', 'myclass'}, {'size', 15}}) %>
A primeira forma irá renderizar o template padrão para string. O segundo formulário irá renderizar o modelo personalizado.
A sintaxe alternativa usa interface fluente:
public class TextBoxViewModel
{
public string Value { get; set; }
IDictionary<string, object> moreAttributes;
public TextBoxViewModel(string value, IDictionary<string, object> moreAttributes)
{
// set class properties here
moreAttributes = new Dictionary<string, object>();
}
public TextBoxViewModel Attr(string name, object value)
{
moreAttributes[name] = value;
return this;
}
}
// and in the view
<%= Html.EditorFor(x => new TextBoxViewModel(x.StringValue).Attr("class", "myclass").Attr("size", 15) %>
Observe que em vez de fazer isso na visualização, você também pode fazer isso no controlador, ou muito melhor no ViewModel:
public ActionResult Action()
{
// now you can Html.EditorFor(x => x.StringValue) and it will pick attributes
return View(new { StringValue = new TextBoxViewModel(x.StringValue).Attr("class", "myclass").Attr("size", 15) });
}
Observe também que você pode fazer a classe TemplateViewModel base - um terreno comum para todos os seus modelos de visualização - que conterá suporte básico para atributos / etc.
Mas, em geral, acho que MVC v2 precisa de uma solução melhor. Ainda é Beta - vá pedir ;-)