▲
一、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");}
▼
.net Mvc4 View—布局页与分部页
时间: 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篇&;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