ASP.NET MVC学习之视图篇(2)
4.HTML辅助器
虽然在ASP.NET MVC中我们已经摆脱了ASP.NET的控件,但是对于页面中需要循环标签的情况依然还是存在,可能很多人认为用foreach就可以完成,但是这个仅仅只是针对单个循环,如果多个循环中都要使用到同样的标签呢?下面笔者就介绍两种方式让我们事半功倍。
首先是针对单个页面的内联辅助器,如果我们遇到只要在单个页面中不断使用的标签的时候,这个方式非常的轻便,比如下面的代码根据文本内容和样式类生成li标签的辅助器(Views/Home/Index.cshtml中):
@helper CreateCssLi(String name,String css)
{
<li class="@css" >@name</li>
} <ul>
@foreach (var item in new[] { new { Name = "ADS", Css = "abs" }, new { Name = "adasd", Css = "afasf" } })
{
@CreateCssLi(item.Name, item.Css)
}
</ul>
这里我们使用了 @helper 生成了一个内联辅助器,并且在下面通过foreach使用了这个内联辅助器,虽然内联辅助器很轻便,但是对于需要在多个视图中使用时,需要在每个页面中写入@helper,所以下面我们还要介绍外部辅助器,能够让我们在不同的页面中也能够使用,我们将上面的内联辅助器改写成如下的外部辅助器:
首先我们新建一个Helper文件夹然后在其中新建一个HtmlHelperExt类,并在其中写入如下代码:
namespace MvcStudy.Helper
{
public static class HtmlHelperExt
{
public static MvcHtmlString CreateCssLi(this HtmlHelper s,String name,String css)
{
var li = new TagBuilder("li");
li.AddCssClass(css);
li.SetInnerText(name);
return new MvcHtmlString(li.ToString());
}
}
}
通过对HtmlHelper进行扩展,那么我们就可以在视图中通过@Html使用我们扩展的方法了,当然仅仅完成这步还不够,在Views的Web.config中添加这个命名空间:
<pages pageBaseType="System.Web.Mvc.WebViewPage">
<namespaces>
<add namespace="System.Web.Mvc" />
<add namespace="System.Web.Mvc.Ajax" />
<add namespace="System.Web.Mvc.Html" />
<add namespace="System.Web.Optimization"/>
<add namespace="System.Web.Routing" />
<add namespace="MvcStudy.Helper"/>
</namespaces>
</pages>
如果读者不想修改配置文件,也有另外一个方法,就是将HtmlHelperExt的namespace改成System.Web.Mvc,最后的效果都一样。
5.分段
相信很多从事ASP.NET的开发人员都使用过母版,而且我们会根据需要在母版中放入ContentPlaceHolder控件作为占位符,那么在最终的内容页面中就会生成同样多的Content控件,这样我们就可以灵活的对页面进行组合。当然这门技术在ASP.NET MVC中依然还是存在,当读者新建一个基本的ASP.NET MVC项目后都会自动的新建好一个母版页面,就是Views/Shared/Layout.cshtml,我们可以打开这个视图,可以发现 @RenderBody() 方法,这个方法其实就是整个内容页的占位符,当然大家一定会问那怎么实现跟ASP.NET一样的效果呢,这个时候分段上场,我们修改_Layout.cshtml的代码:
<body>
@RenderSection("head") @RenderBody() @RenderSection("foot")
@Scripts.Render("~/bundles/jquery")
@RenderSection("scripts", required: false)
</body>
这里通过调用@RenderSection输出内容页中的head段和foot段,剩下来我们修改Views/Home/Index.cshtml视图:
@section head{
<h1>来自head</h1>
}
<h1>来自body</h1>
@section foot{
<h1>来自foot</h1>
}
通过使用@section划分段,然后在其中就可以写入内容了,最后我们可以看到效果如下所示:

但是我们将Index.cshtml中删除一个分段后重新打开,就会报错。因为有时候我们内容页不需要在某个分段中写入内容,如果像上面这样就意味着即使不需要使用也要写这个分段,从而影响视图,当然这个也是有解决方案的,下面我们重新修改_Layout.cshtml页面:
<body>
@RenderSection("head") @RenderBody() @if(IsSectionDefined("foot"))
{
@RenderSection("foot")
}
else
{
<h1>默认的foot</h1>
} @Scripts.Render("~/bundles/jquery")
@RenderSection("scripts", required: false)
</body>
这里我们首先通过@IsSectionDefined判断某个分段是否存在,如果存在则输出,否则输出默认内容,但是我们发现这样还是有点麻烦,有时候我们并没有默认内容,如果不存在这个分段就不显示,所以我们还可以继续修改成如下所示:
<body>
@RenderSection("head") @RenderBody() @RenderSection("foot",false) @Scripts.Render("~/bundles/jquery")
@RenderSection("scripts", required: false)
</body>
我们仅仅在@RenderSection输入了第二个参数为false,这个参数的含义就是这个分段是否是可选。
6.分布视图
上面我们采用了两种辅助器都可以减少我们输入html的数量,但是并不能书写大量的html代码,所以我们还需要一中能够将大量html进行合并,以便视图中随时使用,这个时候我们就可以使用分布视图了,首先我们在Views/Shared下新建视图:
这个要勾选!
笔者的命名为PartialTest,然后我们可以在其中随意写什么。接着我们在Views/Home/Index.cshtml中使用这个分布视图:
@section head{
<h1>来自head</h1>
}
<h1>来自body</h1>
@Html.Partial("PartialTest")
最后我们看到最终的页面中输出了分布视图的内容。但是这种方式仅仅只能解决简单的功能,如果你的分布视图需要涉及到一点功能性的代码,那么它操作起来就比较麻烦了,所以下面我们还需要子动作的帮助。首先我们在Views/Home/Index中新建一个ChildAction视图(注意需要把Layout设置为NULL),然后在Home控制器中写入如下代码:
[ChildActionOnly]
public ActionResult ChildAction()
{
ViewBag.Msg = "来自子动作";
return View();
}
同时我们还需要修改Views/Home/Index视图中的代码如下:
@section head{
<h1>来自head</h1>
}
<h1>来自body</h1>
@Html.Action("ChildAction")
这里注意我们使用的是@Html.Action而不是@Html.Partial,然后我们重新build下然后刷新页面就可以看到子动作的内容了:

关于ASP.NET MVC自带的Html辅助器笔者这里就不介绍了,因为相关的教程很多,而且使用很快就能上手,至此ASP.NET MVC的视图部分就到此为止了。
ASP.NET MVC学习之视图篇(2)的更多相关文章
- ASP.NET MVC学习之视图篇(1)
一.前言 不知道还有多少读者从第一篇开始一直学习到如今,笔者也会一直坚持将ASP.NET MVC的学习完美的结束掉,然后开始写如何配合其他框架使用ASP.NET MVC的随笔.当然笔者后面的随笔如果没 ...
- ASP.NET MVC学习之过滤器篇(2)
下面我们继续之前的ASP.NET MVC学习之过滤器篇(1)进行学习. 3.动作过滤器 顾名思义,这个过滤器就是在动作方法调用前与调用后响应的.我们可以在调用前更改实际调用的动作,也可以在动作调用完成 ...
- ASP.NET MVC学习之控制器篇扩展性
原文:ASP.NET MVC学习之控制器篇扩展性 一.前言 在之前的一篇随笔中已经讲述过控制器,而今天的随笔是作为之前的扩展. 二.正文 1.自定义动作方法 相信大家在开发过程一定会遇到动作方法的重名 ...
- ASP.NET MVC学习之控制器篇
一.前言 许久之后终于可以继续我的ASP.NET MVC连载了,之前我们全面的讲述了路由相关的知识,下面我们将开始控制器和动作的讲解. ASP.NET MVC学习之路由篇幅(1) ASP.NET MV ...
- ASP.NET MVC学习之过滤器篇(1)
一.前言 继前面四篇ASP.NET MVC的随笔,我们继续向下学习.上一节我们学习了关于控制器的使用,本节我们将要学习如何使用过滤器控制用户访问页面. 二.正文 以下的示例建立在ASP.NET MVC ...
- ASP.NET MVC学习之控制器篇(二)
原文链接:http://www.asp.net/learn/mvc/ 这篇教程探索了ASP.NET MVC控制器(controller).控制器动作(controller action)和动作结果(a ...
- ASP.NET MVC学习之路由篇(3)
根据路由输出链接 既然是网站开发自然少不了链接,我们已经学会了强大的路由,但是还缺少一步就是能够将这些路由的路径输出到页面,下面我们就开始学习如何输出路由路径. 首先我们的路由注册部分如下所示: 1 ...
- ASP.NET MVC学习之路由篇(2)
7.解决与物理路径的冲突 当发送一个请求至ASP.NET MVC时,其实会检查网站中存不存在这个请求的物理路径文件,如果存在的话,就会直接将这个物理文件返回.但是有时候我们需要它执行控制器的某个方法, ...
- ASP.NET MVC学习之路由篇(1)
1.基本路由 RouteConfig.cs: 1 public class RouteConfig 2 { 3 public static void RegisterRoutes(RouteColle ...
随机推荐
- 6. js时间比较
var v0 = ABS_DATESTRING(O_PARAMETER.FDate,"yyyy/MM/dd")var v_beginTime = v0 + " " ...
- CSS盒子模型学习记录3(侧面导航栏)
学习http://www.blueidea.com/tech/web/2007/4545_2.asp 代码试验 html <!DOCTYPE html PUBLIC "-//W3C// ...
- Egret中的对象池ObjectPool
为了可以让对象复用,防止大量重复创建对象,导致资源浪费,使用对象池来管理. 对象池具体含义作用,自行百度. 一 对象池A 二 对象池B 三 字符串key和对象key的效率 一 对象池A /** * 对 ...
- javascript 原型详解
引:http://www.cnblogs.com/wangfupeng1988/p/3978131.html 1.什么是javascript原型 每一个函数都有prototype属性(默认生成的)和原 ...
- 基于WDF的PCI/PCIe接口卡Windows驱动程序(2)-开发者需要了解的WDF中的一些重要的概念
原文出处:http://www.cnblogs.com/jacklu/p/4646601.html 本科毕业设计是这方面的工作,所以想开几篇博客来介绍使用WDF开发PCI/PCIe接口卡的驱动程序方法 ...
- JavaWeb项目连接Oracle数据库
参考网址:http://jingyan.baidu.com/article/0320e2c1d4dd0b1b87507b38.html 既然你要链接oracle数据库 ,那么首先就是先打开我们的ora ...
- mysql 查询去除空格字符然后倒入新表
/* 导入数据的时候,有空白字符,去除一下然后导出. 四年前干的事,现在再干一遍. */ $dbhost= '127.0.0.1'; $dbuser= 'root'; $dbpass= '123456 ...
- nginx环境下配置nagiosQL-关于nagiosql配置文件
接上文:nginx环境下配置nagios-关于nginx.conf nagiosql文件应该处于conf/domain/目录下 nagiosql配置如下: ; gzi ...
- windows10-桌面图标不见了,资源管理器的桌面中可以看到??
问题描述: 1. 桌面的图标,在桌面上看不到, 但是在通过资源管理器可以看到, 图标仍然在桌面 2. 桌面仍然可以右击, 就是看不见新建或者拷贝到桌面的所有图标 解决方案: Google 后请参考: ...
- NXP开源自动驾驶计算平台Bluebox 打造现实无人汽车
知名半导体制造商恩智浦NXP已经准备好了自家的自动驾驶计算开源平台Bluebox,将为汽车制造商提供现成的一体化自动 驾驶计算解决方案.专为自动驾驶设备的BlueBox中央计算引擎.不仅能够为无人驾驶 ...