I am going to give a brief introduction, just to get to my enhancement - for more information see this article.
So, if you have this:
<%= Html.EditorFor( mymodel => mymodel.SomeField %>
If SomeField is a boolean, it will generate a checkbox. If SomeField is a string, it will generate a textbox. When it generates the editor it uses a new template system that you can change. So, if you define a partial view called 'string.ascx' in an EditorTemplates folder, it will use that when it encounters a string that needs an editor. You can also specify a [UIHint("myspecialui")] in the data model and it will look for myspecialui.ascx to generate the editor.
One of the recognized shortcomings of EditorFor is the lack of an additional method parameter to specify additional html options, such as the class. So that means you have to go back to TextBoxFor, which does not use any of the new templates.
There are several annotations you can put on your model, some annotations are for use in DisplayFor, EditorFor and ValidatorMessageFor extensions. What is interesting is if you have a [StringLength(20)] attribute on your model, this is used by the default ValidationMessageFor, but not by the default EditorFor template. The MVC 2 beta does not set the maxlength attribute of the input box. So, here is a new implementation of string editor for that does!
Create string.ascx in Views/Shared/EditorTemplates with the following code:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl" %> <% DictionaryPresto! All strings on the site that use EditorFor extension will now have stringlength support in the input box. Templates are a very powerful way to extend. I am not sure the above was the best way to get to the StringLength data annotation - so, if anyone has any improvements let me know!attributes = new Dictionary () { { "class", "text-box single-line " } }; IEnumerable validators = ModelValidatorProviders.Providers.GetValidators(ViewData.ModelMetadata, ViewContext); ModelClientValidationRule rule = validators.SelectMany(v => v.GetClientValidationRules()).FirstOrDefault( m=> m.ValidationType=="stringLength"); if (rule.ValidationParameters.ContainsKey("maximumLength")) { attributes.Add("maxlength", rule.ValidationParameters["maximumLength"]); } %> <%=Html.TextBox("", ViewData.TemplateInfo.FormattedModelValue, attributes)%>
Edit 12/19: Latest version of above code:
<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl" %> <% Dictionaryattributes = new Dictionary () { { "class", "text-box single-line " } }; IEnumerable validators = ModelValidatorProviders.Providers.GetValidators(ViewData.ModelMetadata, ViewContext); ModelClientValidationRule rule = validators.SelectMany(v => v.GetClientValidationRules()).FirstOrDefault(m => m.ValidationType == "stringLength"); if (rule != null && rule.ValidationParameters.ContainsKey("maximumLength")) { attributes.Add("maxlength", rule.ValidationParameters["maximumLength"]); } %> <%=Html.TextBox("", ViewData.TemplateInfo.FormattedModelValue, attributes)%> <% rule = validators.SelectMany(v => v.GetClientValidationRules()).FirstOrDefault(m => m.ValidationType == "required"); if (rule != null) { %> * <%}%>
4 comments:
Hi, I can't seem to get this to work. Do you have a sample project?
John,
I don't have a place to put downloads right now. Did you put [StringLength(20)] attribute on your datamodel member? Is the member a string?
If you did that, then just make sure the above template is in \views\shared\EditorTemplates\string.ascx
Also, I have edited the blog and posted the latest version of this template.
Thanks - I realized it was the fact I'm using ASP.NET 3.5 so this did not work
Dictionary
I just changed it to
Dictionary
and added the null check as you did in the updated version.
Thanks for a great blog!
We a glance at|have a glance at} data safety and regulation, bonus terms and circumstances, sport selection and progressive jackpots. You can {check out|take a glance at|try} all of the casinos that failed to make the grade right right here 메리트카지노 on our list of sites sites|of websites} to keep away from. PASPA was declared unconstitutional outcome of|as a end result of} it interfered with a state's right to repeal its own anti-gambling laws. Shortly thereafter, New Jersey provided authorized sports activities betting to its residents.
Post a Comment