该篇文章是Stephen Walther博客中的文章,个人觉得不错就翻译了一下。但由于个人英语水平有限,还望各位海量。如果想看原文,请点击ASP.NET MVC Tip #1 - Create New HTML Helpers with Extension Methods查看原文
这个提示里,我会展示给大家怎样创建能在Asp.net MVC 的view中应用的两个心得HTML Helpers。我会展示给大家通过使用扩展函数创建一个新的显示项目符号和数组列表的HTML Helpers。
当你创建一个Asp.net MVC程序的View时,你可以使用利用HTML Helpers提供标准的HTML标记。例如,<input name="inpSubmit" type="submit" value="Click Here!" />的标记可以使用<%= Html.SubmitButton("inpSubmit", "Click Here!") %>代替。从长远方面看,使用HTML Helpers能够节省很多时间。但是如果现有的HTML Helpers中没有你要使用的的标记那该怎么办?例如,设想你要在View中以符号列表的形式显示数据库的记录集。现有的HtmlHelper中没有包含显示符号列表的方法。不要放弃,如果HtmlHelper中没有包含要使用的方法时,扩展一个就可以了。
你可以通过创建扩展函数添加新的功能性的HtmlHelper类。一个扩展方法看起来就像一个平常的实例化方法。不管怎样,和一般实例化方法不同,你向一个类中添加扩展方法通过在完全不同的类中定义方法。(这个句子有点不同,希望达人帮助解答一下However, unlike a normal instance method, you add extension methods to a class by defining the methods in a completely different class.)
在C#中,你定义扩展方法在一个静态类中并使用this关键字表明这个类被扩展。
这儿向HtmlHelper类添加扩展方法用于显示顺序或不按顺序排列数据集。
![](https://www.cnblogs.com/Images/OutliningIndicators/None.gif)
2
![](https://www.cnblogs.com/Images/OutliningIndicators/None.gif)
3
![](https://www.cnblogs.com/Images/OutliningIndicators/None.gif)
4
![](https://www.cnblogs.com/Images/OutliningIndicators/None.gif)
5
![](https://www.cnblogs.com/Images/OutliningIndicators/None.gif)
6
![](https://www.cnblogs.com/Images/OutliningIndicators/None.gif)
7
![](https://www.cnblogs.com/Images/OutliningIndicators/None.gif)
8
![ExpandedBlockStart.gif](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
![ContractedBlock.gif](https://www.cnblogs.com/Images/OutliningIndicators/ContractedBlock.gif)
![](https://www.cnblogs.com/Images/dot.gif)
9
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
10
![ExpandedSubBlockStart.gif](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](https://www.cnblogs.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![](https://www.cnblogs.com/Images/dot.gif)
11
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
12
![ExpandedSubBlockStart.gif](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](https://www.cnblogs.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![](https://www.cnblogs.com/Images/dot.gif)
13
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
14
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
15
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
16
![ExpandedSubBlockStart.gif](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](https://www.cnblogs.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![](https://www.cnblogs.com/Images/dot.gif)
17
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
18
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
19
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
20
![ExpandedSubBlockStart.gif](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](https://www.cnblogs.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![](https://www.cnblogs.com/Images/dot.gif)
21
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
22
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
23
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
24
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
25
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
26
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
27
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
28
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
29
![ExpandedSubBlockStart.gif](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
![ContractedSubBlock.gif](https://www.cnblogs.com/Images/OutliningIndicators/ContractedSubBlock.gif)
![](https://www.cnblogs.com/Images/dot.gif)
30
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
31
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
32
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
33
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
34
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
35
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
ListExtentsions类有两个公共方法:OrderedList()和UnorderedList()。你通过向任何一个方法传递一个items集合来显示一个按序和不按序排列的列表。注意这些方法返回的是string类型。实际上,HtmlHelper方法仅仅是向浏览器提供一个string格式化的函数。
在你创建一个扩展方法后,可在一个View页面中适用这个方法。
![ContractedBlock.gif](https://www.cnblogs.com/Images/OutliningIndicators/ContractedBlock.gif)
![ExpandedBlockStart.gif](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
<%=Html.ActionLink("excel1","GenerateExcel1") %><br />
<%=Html.ActionLink("excel2","GenerateExcel2") %><br />
<%=Html.ActionLink("excel3","GenerateExcel3") %>
注意项目符号类表的HtmlHelper的命名空间在文件的头部引入。Html.OrderedList()方法用于显示数字排序的列表,Html.UnorderedList()方法用于呈现符号类表。注意这些在HtmlHelper的方法就像其他的扩展方法一样都是通过View的Html属性暴露的。
2 public ActionResult BulletedList()
3 {
4 var cat = from c in db.Categories select c.CategoryName;
5 ViewData[ " Catories " ] = cat;
6 ViewData[ " Title " ] = " BulletedList Test " ;
7 return View();
8 }
你可以在其他任何的Asp.net MVC的View页面中使用这个扩展函数。