.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");}
  ▼

时间: 2025-01-14 01:41:58

.net Mvc4 View—布局页与分部页的相关文章

asp.net MVC 4.0 View回顾——布局页与分部页

asp.net MVC 4.0中总结 视图里加载部分视图几种方法 @RenderPage() 但它不能使用 原来视图的 Model 和 ViewData ,只能通过参数来传递. 1 @RenderPage("~/Shared/Component/Dialog.cshtml", new { title = "Hello world!", content="Nani" }) 分部视图接收数据通过Page 1 <div id="dial

爱上MVC~在Views的多级文件夹~续~分部页的支持

回到目录 之前写的一篇文章,主要针对View视图,它可以放在N级目录下,不必须非要在views/controller/action这种关系了,而在程序运行过程中,发现分页视图对本功能并不支持,原因很简单,在RazorViewEngine有不同的属于来修饰这两个东西,对于View的查找,通过ViewLocationFormats来定义,而分部视图的查找通过PartialViewLocationFormats来定义,它们定义了视图的查询范围,如~/Views/LindAdmin/{1}/{0}.cs

MVC的布局页,视图布局页和分布页的使用

一,结构如下图 二,布局页和视图布局页 1>使用方法一 _ViewStart.cshtml @{ Layout = "~/Views/Shared/_Layout.cshtml"; } <h2>视图布局页_ViewStart.cshtml</h2> _Layout.cshtml <!DOCTYPE html> <html> <head> <meta name="viewport" content

ASP.NET MVC5 之 分部页

1.分部页 _PartialPage.cshtml @model List<string> <a>完美世界</a> @foreach (var item in Model) { <li>@item</li> } 2.HomeController.cs 和 index.html public ActionResult Index() {      var testObj = new List<string>()     {       

html万能排版布局插件,web视图定位布局创意技术演示页

html万能排版布局插件,是不是感觉很强大,原理其实很简单,不过功能很强大哈哈,大量节省排版布局时间啊! test.html <!doctype html> <html> <head> <meta charset="utf-8"> <title>web视图定位布局创意技术演示页</title> <meta content="width=device-width,initial-scale=1.0,m

iOS开发——UI_swift篇&amp;TableView实现页眉和页脚

TableView实现页眉和页脚 UITableView具有var tableHeaderView:UIView?属性和var tableFooterView:UIView?属性,可以通过给其赋值来创建列表TableView的页眉和页脚. 效果图如下: 代码如下: 1 import UIKit 2 3 class ViewController: UIViewController,UITableViewDelegate, 4 UITableViewDataSource,UIGestureRecog

C# Winform学习---MDI窗体的设计,PictureBox控件(图片上一页下一页),Timer控件,MenuStrip控件

一.MDI窗体的设计 1.MDI简介 MDI(Multiple Document Interface)就是所谓的多文档界面,与此对应就有单文档界面 (SDI), 它是微软公司从Windows 2.0下的Microsoft Excel电子表格程序开始引入的,Excel电子表格用户有时需要同时操作多份表格,MDI正好为这种操作多表格提供了很大的方便,于是就产生了MDI程序 2.效果图: 如下图所示,多窗体嵌套,其中一个是父窗体,其条是子窗体. 横向排列下面的窗体: 纵向排列下面的窗体: 关闭全部子窗

欢迎页,引导页和主页

配置 <application         android:name="com.shipping.application.ShippingApplication"         android:allowBackup="true"         android:icon="@drawable/ic_launcher"         android:label="@string/app_name"        

Swift - 给表格TableView添加页眉和页脚

UITableView具有var tableHeaderView:UIView?属性和var tableFooterView:UIView?属性,可以通过给其赋值来创建列表TableView的页眉和页脚. 效果图如下: 代码如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48