ASP.Net MVC 布局页、模板页使用方法详细介绍
一、Views文件夹->Shared文件夹下的_Layout.cshtml母版页
@RenderBody
当创建基于_Layout.cshtml布局页面的视图时,视图的内容会和布局页面合并,而新创建视图的内容会通过_Layout.cshtml布局页面的@RenderBody()方法呈现在标签之间。
@RenderPage
从名称可以猜出来这个方法是要呈现一个页面。比如网页中固定的头部可以单独放在一个共享的视图文件中,然后在布局页面中通过这个方法调用,用法如下:
@RenderPage(“~/Views/Shared/_Header.cshtml”)
带参数
@RenderPage(“~/Views/Shared/_Header.cshtml”,new{parm="my",parm2="you")
调用页面获取参数:
//获取RenderPage()传递过来的参数
@PageData["param"]
@RenderSection
布局页面还有节(Section)的概念,也就是说,如果某个视图模板中定义了一个节,那么可以把它单独呈现出来
为了防止因缺少节而出现异常,可以给RenderSection()提供第2个参数:
@RenderSection("head",false)
或
@if(IsSectionDefined("head"))
{
@RenderSection("head",false)
}
else
{
SubMenuSectionisnotdefined!
}
代码如下:
@ViewBag.Title @RenderSection("head",required:true)@*View页面自定义特定js/css使用*@ @RenderPage("~/Views/Shared/_Header.cshtml") @RenderBody()
二、创建视图,使用母版页
代码如下:
@{ ViewBag.Title="Index"; Layout="~/Views/Shared/_Layout.cshtml"; }Index
@sectionHead{$(function(){ alert("hellojquery"); }); } 执行C#普通语法
@DateTime.Now.Date.ToShortDateString()执行C#语句段
@{ Listlist=newList {"Mvc3","Razor"}; list.Add(".Net4"); } @foreach(stringsinlist) { if(string.IsNullOrEmpty(s)) {
- 空
} else {- @s
} }
三、生成页面的源代码
Index $(function(){ alert("hellojquery"); }); Index
执行C#普通语法
2013/3/11执行C#语句段
- Mvc3
- Razor
- .Net4
四、@Html.Partial
Partial每次都会创建自己的TextWriter实例并且把内容缓存在内存中.最后把所有writer输出的内容发送到一个MvcString对象中
更多时候我们会使用@{Html.RenderPartial("Details");}而不是@Html.Partial
Html.RenderPartial()与@Html.Partial的区别
Html.RenderPartial直接输出至当前HttpContext(因为是直接输出,所以性能好)。
Html.Partial将视图内容直接生成一个字符串并返回(相当于有个转义的过程)。
RenderPage()和RenderPartial()的区别
RenderPage()调用的页面只能使用其传递过去的数据。
而RenderPartial()是可以使用viewdata,model等数据的。
如:@{Html.RenderPartial("BasicChart",model);}
用这个重载可以在部分视图里使用强类型,然后在主视图中使用第二个参数传model过去
@{Html.RenderPartial("BasicChart",ViewData["myData"]);}
Html.RenderPartial和Html.RenderAction的区别
Html.RenderPartial适合用在重覆使用的UserControl,并且只需要透过Model来呈现内容,或是对于广告的UserControl也适合使用。
Html.RenderAction则会先去呼叫Controller的Action方法,如果此UserControl是需要透过资料库取得资料来呈现(透过Action来读取资料库),此时会比较适合使用此方式。
补充:
1、带有Render的方法返回值是void,在方法内部进行输出;不带的返回值类型为MvcHtmlString,所以只能这样使用:
@Html.Partial对应@{Html.RenderPartial(....);}
@Html.Action对应@{Html.RenderAction(....);}
2、Html.Partial可以直接提供用户控件名作为参数,而Html.Action需要有对应的Action,在Action内部返回PartailResult(即retunPartialView())。
3、对于简单的没有任何逻辑的用户控件,推荐使用Html.Partial;对于需要设置一些Model的用户控件,推荐使用Html.Action。当然,有Model数据也是可以使用Html.Partial方法的,可以看方法的重载。
4、使用Html.Action有个好处,就是可以根据不同的场景选择不同的用户控件。
比如:
@Html.Action("UserInfoControl")
在对应的UserInfoControl这个Action中,在用户未登录的时候,可以retunPartialView("LogOnUserControl");登录后,可以retunPartialView("UserInfoControl");
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。