Asp.net MVC5 框架揭秘 S412 实例解析 – 绝妙的扩展 模式的胜利

 

Asp.net MVC5 框架是个 开源的,处处可扩展的框架。

蒋先生 在他的这本书里 对如何理解框架,如何扩展框架, 给出了大量的说明和实例。

先上效果图

大部分做传统BS 的同学看到这个页面,脑海里的第一反应 就是一堆HTML 一堆控件 然后 后台绑定什么的吧。

但请看页面的代码。

  1. @model MvcApp.Models.Employee
  2. <html>
  3. <head>
  4.     <title>编辑员工信息</title>
  5. </head>
  6. <body>
  7.     <table>
  8.         <tr>
  9.             <td>@Html.LabelFor(m => m.Name)</td>
  10.             <td>
  11.                 @Html.EditorFor(m => m.Name)
  12.             </td>
  13.         </tr>
  14.         <tr>
  15.             <td>@Html.LabelFor(m => m.Gender)</td>
  16.             <td>
  17.                 @Html.EditorFor(m => m.Gender)
  18.             </td>
  19.         </tr>
  20.         <tr>
  21.             <td>@Html.LabelFor(m => m.Education)</td>
  22.             <td>
  23.                 @Html.EditorFor(m => m.Education)
  24.             </td>
  25.         </tr>
  26.         <tr>
  27.             <td>@Html.LabelFor(m => m.Departments)</td>
  28.             <td>
  29.                 @Html.EditorFor(m => m.Departments)
  30.             </td>
  31.         </tr>
  32.         <tr>
  33.             <td>@Html.LabelFor(m => m.Skills)</td>
  34.             <td>
  35.                 @Html.EditorFor(m => m.Skills)
  36.             </td>
  37.         </tr>
  38.     </table>
  39. </body>
  40. </html>

怎么做的呢? 这个MvcApp.Models.Employee 又是什么呢?为什么会很神奇的变成一堆 各种各样的 list 控件呢?

  1. namespace MvcApp.Models
  2. {
  3.     public class Employee
  4.     {
  5.         [DisplayName("姓名")]
  6.         public string Name { get; set; }
  7.  
  8.         [RadioButtonList("Gender")]
  9.         [DisplayName("性别")]
  10.         public string Gender { get; set; }
  11.  
  12.         [DropdownList("Education")]
  13.         [DisplayName("学历")]
  14.         public string Education { get; set; }
  15.  
  16.         [ListBox("Department")]
  17.         [DisplayName("所在部门")]
  18.         public IEnumerable<string> Departments { get; set; }
  19.  
  20.         [CheckBoxList("Skill")]
  21.         [DisplayName("擅长技能")]
  22.         public IEnumerable<string> Skills { get; set; }
  23.     }
  24. }

看到这里对C# 和 .net 熟悉的同学一定心理有点谱了吧,特性!哦原来全是通过特性反射的呀。那又是如何反射的呢?

 

 

ListAttribute 继承了IMetadataAware 接口 然后MVC框架在创建View Model 时就会触发 事件 OnMetaDataCreated。

接着MVC 框架再通过 TemplateHint 确定了各个特性会对应的子模板,这里完全是通过名称的映射一一对应的。

然后再在模板中通过代码@Html.DropDownList("", listName, Model)

去调用对自定义的对HtmlHelper 的扩展方法 DropDownList然后在这个扩展方法中再去取得需要的列表数据IEnumerable<ListItem>再根据这个列表数据来构建需要的List<SelectListItem>

最后再调用已有的htmlHelper.DropDownList(name, selectListItems); 返回了需要的MvcHtmlString

整个扩展到此完毕。

同时还有许多疑点可以深究。

比如@Html.DropDownList("", listName, Model) 这段代码的第一个参数,到底起了什么作用呢?为什么是个空值呢?

通过实际测试我发现在赋空值和非空的情况下生成的HTML 有如下区别。

  1. "" 参数
  2. <tr>
  3.    <td><label for="Education">学历</label></td>
  4.    <td>
  5.      <select id="Education" name="Education"><option value="H">高中</option>
  6.        <option value="B">大学本科</option>
  7.        <option selected="selected" value="M">硕士</option>
  8.        <option value="D">博士</option>
  9.      </select>
  10.    </td>
  11. </tr>
  12. "Test" 参数
  13. <tr>
  14.    <td><label for="Education">学历</label></td>
  15.    <td>
  16.      <select id="Education_test" name="Education.test"><option value="H">高中</option>
  17.      <option value="B">大学本科</option>
  18.      <option selected="selected" value="M">硕士</option>
  19.      <option value="D">博士</option>
  20.      </select>
  21.    </td>
  22. </tr>

具体为何会有如上区别,请去研究代码看书吧。

玩Asp.net MVC 的同学 你真的发挥出 Asp.net MVC 这个框架的强大威力了么?

posted @ 2015-04-24 16:56  默蛇  阅读(1236)  评论(0编辑  收藏  举报