.net Mvc4 View—布局页与分部页
▲
一、Layout属性
1.1、@RenderPage():渲染制定的页面到占位符。
注意:@RenderPage()可以使用多次,这点与@RenderBody()不同
格式如: @RenderPage("~/Views/Home/Test.cshtml");则会把Test.cshtml页面内容加载到指定位置
1.2、@RenderBody():直接渲染整个View到占位符处,不需要原来的<asp:Content/>(呈现子页的主体内容)
注意:@RenderBody()只能在_Layout.cshtml使用一次。
1.3、@RenderSection():声明一个占位符,和原来的<ContentPlaceHoler/>类似(呈现特别的杰部分)
可以有两种声明方式:
第一种方式(推荐):
@RenderSection("SectionA",false)
第2个参数为false,代表在详细View中可以实现,也可以不实现
第2个参数为true,代表在详细View中必须要实现,否则报错
第二种方式: (IsSectionDefined()判断是否有子页实现)
@if(IsSectionDefined("SectionB")){
@RenderSection("SectionB");}
格式如:@RenderSection("SectionA") 在_layout.cshtml页(母版页)这里相当于一个占位符
结合
@section SectionA{
这是@RenderSection("SectionA")呈现出的内容。
}(这是子页面)
二、RenderPartial, RenderAction , Partial , Action 的使用选择
2.1、Html.RenderPartial:将分部视图直接写入响应输出流,所以只能放在代码模块中,不能放在表达式中。
2.1.1、这个方法会直接将结果写入到当前请求的http response数据流中,这以为着它使用了和当前webpage/template使用的相同的TextWrite对象
2.1.2、方法没有返回值
2.1.3、不需要创建action,使用简单
2.1.4、格式如下:@{Html.RenderPartial("Links")};"Links"就是分部视图页的名称
2.1.5、这个方法比Partial方法更快,因为它直接将结果系统到当前响应的数据流中
2.2、Html.RenderAction:将分部视图直接写入响应输出流。
2.2.1、和上个一样,执行结果会直接写入当前响应的数据流中
2.2.2、需要创建child action方法
2.2.3、格式如:@{Html.RenderAction("Category","Home");}
2.2.4、如果你想缓存partial view,这是最好的选择
2.2.5、这个方法比Action()方法快,基于第一条原因
2.3、Html.Partial:以HTML-encoded 字符串展示
2.3.1、结果以HTML-encoded 字符串展示
2.3.2、返回的是string类型,所以结果可以存储在变量里
2.3.3、使用简单,无需创建Action
2.3.4、格式如:@Html.Partial("_Comments")
2.4、Html.Action:直接展示为HtmlString
2.4.1、直接展示为HtmlString
2.4.2、需要创建对应的child action
2.4.3、可以缓存partial view
2.4.4、格式如:@{Html.Action("Category","Home");}
▼