前面几篇文章介绍了一下ASP.NET MVC中的一些基础,今天我们一起来学习一下在ASP.NET MVC中控件的封装。在页面中我们会经常使用到Html对象,来程序控件,当然这里的控件不是说ASP.NET中包含很多ViewState或其他信息的控件。在ASP.NET MVC中控件就是扩展方法,主要对HtmlHelper实例的扩展,不过这里主要会提到CheckBoxList和RadioButtonList的扩展,因为在微软自带的控件中是没有这两个控件存在的,所以我们需要自己扩展。最后还会介绍一下,Html.CheckBoxFor这个控件在使用时会有两个值,在服务端进行判断的结果。
ASP.NET MVC(包含MVC3.0,MVC4.0)中的控件都在System.Web.Mvc中,这里需要了解一下HtmlMvcString和普通的string的区别。在我看来HtmlMvcString就是对string进行编码,使得浏览器能够正确解析HTML字符串。这样在前台显示时就不需要使用Html.Raw方法对字符串进行编码,否则显示的字符串将不会解析成HTML代码。这个只需了解就可以了,有兴趣可以试试就知道所以然了,所以MVC控件都需要返回这个对象。
在ASP.NET MVC中,lumbda表达式是很经常用的,而且非常好用。在页面中声明了一个模型,那样就可以使用lumbda表达式进行实例的赋值和判断,当然在对控件扩展时就会预见到表达式的使用,这些都是.NET3.5的特性,这里就不多赘述。
1 /// <summary>
2 /// 复选框扩展。
3 /// </summary>
4 /// <typeparam name="TModel">模型类型。</typeparam>
5 /// <typeparam name="TProperty">属性类型。</typeparam>
6 /// <param name="helper">HTML辅助方法。</param>
7 /// <param name="expression">lambda表达式。</param>
8 /// <param name="selectList">选择项。</param>
9 /// <param name="htmlAttributes">HTML属性。</param>
10 /// <returns>返回复选框MVC的字符串。</returns>
11 public static MvcHtmlString CheckBoxListFor<TModel, TProperty>(this HtmlHelper<TModel> helper, Expression<Func<TModel, TProperty>> expression, IEnumerable<SelectListItem> selectList, ButtonFormatter formatter = ButtonFormatter.Horizontal, IDictionary<string, object> htmlAttributes = null)
12 {
13 if(selectList == null || expression == null)
14 return MvcHtmlString.Empty;
15 string name = ExpressionHelper.GetExpressionText(expression);
16 List<string> values = null;
17 object obj = helper.ViewData.Eval(name);
18 if(obj != null)
19 values = obj.ToString().Split<string>();
20 else
21 values = new List<string>();
22
23 StringBuilder sb = new StringBuilder();
24 int index = 0;
25 foreach(var item in selectList)
26 {
27 TagBuilder tag = new TagBuilder("input");
28 tag.MergeAttributes<string, object>(htmlAttributes);
29 tag.MergeAttribute("type", "checkbox", true);
30 tag.MergeAttribute("name", name, true);
31 tag.MergeAttribute("id", name + index, true);
32 tag.MergeAttribute("value", item.Value, true);
33 if(values.Contains(item.Value))
34 tag.MergeAttribute("checked", "checked", true);
35 sb.AppendLine(tag.ToString(TagRenderMode.SelfClosing) + " ");
36 TagBuilder label = new TagBuilder("label");
37 label.MergeAttribute("for", name + index);
38 label.InnerHtml = item.Text;
39 sb.AppendLine(label.ToString());
40 if(formatter == ButtonFormatter.Vertical)
41 sb.AppendLine("<br />");
42 index++;
43 }
44 return new MvcHtmlString(sb.ToString());
45 }
46
47 /// <summary>
48 /// 复选框扩展。
49 /// </summary>
50 /// <typeparam name="TModel">模型类型。</typeparam>
51 /// <typeparam name="TProperty">属性类型。</typeparam>
52 /// <param name="helper">HTML辅助方法。</param>
53 /// <param name="expression">lambda表达式。</param>
54 /// <param name="selectList">选择项。</param>
55 /// <param name="htmlAttributes">HTML属性。</param>