在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
在ASP.NET MVC框架中没有了自己的控件,页面显示完全就回到了写html代码的年代。还好在asp.net mvc框架中也有自带的HtmlHelper和UrlHelper两个帮助类。另外在MvcContrib扩展项目中也有扩展一些帮助类,这样我们就不光只能使用完整的html来编写了需要显示的页面了,就可以使用这些帮助类来完成,但最后运行时都还是要生成html代码的。
System.Web.Mvc.HtmlHelper学习及使用 先来看看HtmlHelper能帮我们生成一些什么样的html呢。直接看效果吧。 1.使用HtmlHelper生成超链接: <a href="/">我是超链接</a> <form act <input />复选框 5.使用HtmlHelper生成上拉列表框:
其实大家可能注意到了,当我们在使用<%%>中有同样都是使用的HtmlHelper中的方法,为什么有的需要加上等号,有的不需要,其实在HtmlHelper中的方法中,只要是返回的是MvcHtmlString类型的方法都需要使用等号将值输出。
大家对ASP.NET MVC 2要求的一个常用特性是,要我们支持强类型的HTML辅助方法,这样的辅助方法使用 lambda 表达式来引用传到视图模板中的模型或视图模型。这可以促成更好的编译时视图检查(可以在编译时发现缺陷,而不是在运行时),还可以促成视图模板中更好的代码intellisense支持。 新的强类型HTML辅助方法现在已经内置于ASP.NET MVC 2中了,这些方法使用"Html.HelperNameFor()”的命名规范。例如,Html.TextBoxFor(), Html.CheckBoxFor(), Html.TextAreaFor()等等。它们支持使用lambda表达式来指定元素的名称和id,以及要显示的值。 例如,除了上面的Html.TextBox()辅助方法外,使用ASP.NET MVC 2,我们现在还可以使用新的Html.TextBoxFor()辅助方法: 注意上面,我们不再需要指定 “ProductName” 字符串参数,lambda表达式是相当灵活的,除了值以外,我们还可以获取我们模型对象中的属性/字段的名称。 因为这些HTML辅助方法是强类型的,编写lambda表达式时我们还可以在Visual Studio中得到完整的intellisense支持: 显示的HTML跟前面的后期绑定的HTML辅助方法版本的输出是一样的: 内置于ASP.NET MVC 2中的强类型HTML辅助方法列表ASP.NET MVC 2对下列强类型的HTML辅助方法提供内置支持: HTML元素辅助方法:
其他辅助方法:
System.Web.Mvc.UrlHelper的学习与使用 我们学习一下UrlHelper帮助类,看类名也都知道这个类是用来帮我们生成URL在ASP.NET MVC应用程序中。让我们来看看该类给我们带来了哪些方便的方法和属性,UrlHelper提供了四个非常常用的四个方法, 1.Act 2.Content方法是将一个虚拟的,相对的路径转换到应用程序的绝对路径, 3.Encode方法是对URL地址进行加密,与Server.Encode方法一样。 4.方法是提供在当前应用程序中规定的路由规则中匹配出URL。 另外还有两个属性,分别是RequestContext和RouteCollection两个属性,分别指的是包含HTTP上下文和RouteData两个属性,另外,RouteCollection是整个当前应用程序中规定的路由规则。 下面对上面的方法使用写成代码看
1.使用Act <a href='<%= Url.Act <a href='<%= Url.Act <a href='<%= Url.Act <a href='<%= Url.Act <a href='<%= Url.Act <a href='<%= Url.Act <a href='<%= Url.Act <% var rvd = new RouteValueDictionary(); rvd.Add("id", 5); rvd.Add("category", 2); var tmp = 5; %> <a href='<%= Url.Act <a href='/simple/DemoAction' title="">指定Act <a href='/id/DemoAction' title="">指定Act <a href='/simple/DemoAction?id=2&category=5' title="">指定Act <a href='/DemoController/DemoAction' title="">指定Act <a href='/DemoController/DemoAction?Length=2' title="">指定Act <a href='/DemoController/DemoAction?id=2&category=5' title="">指定Act <a href='https://localhost/DemoController/DemoAction?id=2&category=5' title="">指定传输协议生成URL</a> <a href='https://local/DemoController/DemoAction?id=5&category=2' title="">指定主机名生成URL</a> 2.使用Content方法将虚拟(相对)路径生成为绝对路径 <a href='<%= Url.Content("~/DemoController/DemoAction")%>' title="">指定虚拟路径生成绝对路径</a> <a href='/DemoController/DemoAction' title="">指定虚拟路径生成绝对路径</a> 3.使用Encode加密URL <a href='<%= Url.Encode("http://www.cnblogs.com/longgel/")%>' title="">加密过的URL连接</a> <a href='http%3a%2f%2fwww.cnblogs.com%2flonggel%2f' title="">加密过的URL连接</a> 4.使用RouteUrl生成URL <a href='<%= Url.RouteUrl(tmp)%>' title="">指定RouteValue生成URL</a> <a href='<%= Url.RouteUrl("Default")%>' title="">指定RouteName生成URL</a> <a href='<%= Url.RouteUrl(rvd)%>' title="">指定多个参数生成URL</a> <a href='<%= Url.RouteUrl("Default",tmp) %>' title="">指定路由规则名和单个路由值</a> <a href='<%= Url.RouteUrl("Default",rvd) %>' title="">指定路由规则名和多个路由值</a> <a href='<%= Url.RouteUrl("Default",tmp,"https") %>' title="">指定传输协议</a> <a href='<%= Url.RouteUrl("Default",rvd,"https","www.cnblogs.com") %>' title="">指定主机名</a> <a href='/simple/urlhelperdemo' title="">指定RouteValue生成URL</a> <a href='/Longgel/Index/Id' title="">指定RouteName生成URL</a> <a href='/simple/urlhelperdemo?id=5&category=2' title="">指定多个参数生成URL</a><br />/Longgel/Index/Id <a href='/Longgel/Index/Id' title="">指定路由规则名和单个路由值</a> <a href='/Longgel/Index/Id?id=5&category=2' title="">指定路由规则名和多个路由值</a> <a href='https://localhost/Longgel/Index/Id' title="">指定传输协议</a> <a href='https://www.cnblogs.com/Longgel/Index/Id?id=5&category=2' title="">指定主机名</a>
|
请发表评论