MVC - 布局
布局类似于APSX视图的母版页 用的是Razor的语法
创建布局
布局页面默认放在Shared目录 有几个自动生成的cshtml文件 删除它们 然后创建一个视图 命名为MyLayOut 取消勾选使用母版页或布局 打开该文件 删除以下代码
@{
Layout = null;
}
我们将这个文件当做一个布局页面来使用 首先需要修改Views目录下的_ViewStart.cshtml 因为我们删掉了默认的布局页 所以在此视图中需要修改Layout的值 让其指向我们自定义的布局页
@{
Layout = "~/Views/Shared/MyLayOut.cshtml";
}
接着就可以使用以下方法来渲染子页面视图到布局页面中
RenderBody方法
渲染一个子视图 只要子视图是根据当前布局页创建的 则RenderBody指向的就是该视图 如
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>MyLayOut</title>
</head>
<body>
<div style="background:#ff5252;width:400px;height:100px;font:12px 微软雅黑;padding:10px;color:white;">
<h1>布局页</h1>
</html>
然后在控制器中创建一个ChildPage的Action方法
public ActionResult ChildPage()
{
return View();
}
为该Action创建一个视图 选择MyLayOut作为布局页

生成的ChildPage如下 在视图中创建一个div 输入文本ChildPage
@{
ViewBag.Title = "ChildPage";
Layout = "~/Views/Shared/MyLayOut.cshtml";
}
<lable>ChildPage</lable>
运行一下 请求default/childpage 结果如图

RenderPage方法
此方法是将一个固定的视图页面渲染到布局页中 可以在布局中多次使用 而RenderBody指向的是一个动态的视图 只能在布局中使用一次 只要A视图是引用布局页创建的 那么访问A视图 就会先加载布局页 布局页的RenderBody指的就是A视图 如果B视图也引用了布局页 那么访问B视图 也会先加载布局页 布局页RenderBody指的就是B视图
比如我们可以将菜单这种固定的视图渲染到布局中 首先我们修改一下布局页
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>MyLayOut</title>
</head>
<body>
<div style="background:#ff5252;width:600px;height:250px;font:12px 微软雅黑;padding:10px;color:white;">
<h1>布局页</h1>
<div>
<div style="float:left;">@RenderPage("~/Views/Default/Menu.cshtml")</div>
<div style="float:left;margin-left:30px;background:black; width:200px;">@RenderBody()</div>
</div>
</div>
</body>
</html>
现在还没有Menu视图 创建一个Action方法Menu 为其添加视图 选择分布视图 取消勾选使用母版页或布局
.uls1{
margin:0;
padding:0;
list-style:none;
}
.links1{
color:white;
font:13px Arial;
display:block;
border-left:12px solid #87bbbc;
border-right:1px solid #87bbbc;
padding-right:2px;
text-decoration:none;
}
.lis1{
border-bottom:1px solid #b0eeef;
}
.links1:hover{
background:#8fc9b8;
border-left:12px solid white;
}
.deadenlink{
background:#87bcac;
border-left:12px solid black;
color:white;
font:13px Arial;
display:block;
border-left:12px solid black;
border-right:1px solid #87bbbc;
padding-right:2px;
text-decoration:none;
}
.deadenlink:hover{
background:#b0d5ef;
border-left:12px solid #e60b39;
}
</style>
<div class='navigationbox'>
<ul class="uls1">
<li class="lis1"><a href='#' class="links1">Google</a></li>
<li class="lis1"><a href='#' class="links1">Microsoft</a></li>
<li class="lis1"><a href='#' class='deadenlink'>Netscape</a></li>
<li class="lis1"><a href='#' class="links1">W3C</a></li>
<li class="lis1"><a href='#' class="links1">线性代数</a></li>
<li class="lis1"><a href='#' class='deadenlink'>斯诺克</a></li>
<li class="lis1"><a href='#' class="links1">芝宝打火机</a></li>
<li class="lis1"><a href='#' class="links1">吴哥窟</a></li>
</ul>
</div>
运行一下 请求default/childpage 结果如图 可以看到布局页加载了一个固定的视图Menu 和一个动态的ChildPage视图

RenderSection方法
该方法声明了一个占位符 它会渲染指定的视图的一个部分 此方法专门用于使用了布局的各个视图 可以设置视图中某一部分的数据要显示在布局页中的某个位置上 我们知道RenderBody在布局页面中只能使用一次 而无法很灵活的将视图的某一部分定位在布局页面的某个位置 RenderSection可以解决这个问题 该方法参数1指定的是一个占位符的名字 参数2指定的是内容是否是必须的 一般设为false即可 在布局中如下使用该方法
@RenderBody()
<p>@RenderSection("part",false)</p>
在ChildPage视图中通过section 指定要使用的占位符名字
@{
ViewBag.Title = "ChildPage";
Layout = "~/Views/Shared/MyLayOut.cshtml";
}
<lable>ChildPage</lable>
@section part{
<lable>Copyright ©2013 Tom</lable>
}
这样 section 中的内容<lable>Copyright ©2013 Tom</lable>将显示在布局页的p标签中
MVC - 布局的更多相关文章
- IOS 整体架构 和 MVC布局
IOS的生态系统 IOS生态系统不仅仅是指产品,更重要的是指 iPhone/iPad/iPod/Mac +iCloud+App整个系统,包括Siri (部分设备不支持).FaceTime.Safari ...
- Best MVC Practices(最优的MVC布局)
Best MVC Practices 最优的MVC布局策略 Model View Controller 1.数据层 2.视图层 3.控制器层 Although Model-View-Controlle ...
- ASP.NET MVC布局
一.Views文件夹 -> Shared文件夹下的 _Layout.cshtml 母版页 @RenderBody 当创建基于_Layout.cshtml布局页面的视图时,视图的内容会和布局页面合 ...
- ASP.Net MVC 布局页 模板页 使用方法详细说明
一.Views文件夹 -> Shared文件夹下的 _Layout.cshtml 母版页 @RenderBody 当创建基于_Layout.cshtml布局页面的视图时,视图的内容会和布局页面合 ...
- mvc布局(一)
negut添加Optimization @System.Web.Optimization.Styles.Render( "~/Content/styles/css/font-awesome. ...
- MVC布局页占位符@RenderSection("bscript", false)
@RenderSection("bscript", false) //false表示不是必须填充 填充bscript占位符 @section bscript{}
- MVC之LayOut布局页
LayOut布局页,就是相当于WebForm中母版页,实现了一个代码的共用和公共布局的作用. 布局页的使用 (1)添加新项,选择MVC布局页 <!DOCTYPE html> <htm ...
- ASP.Net MVC开发基础学习笔记:五、区域、模板页与WebAPI初步
一.区域—麻雀虽小,五脏俱全的迷你MVC项目 1.1 Area的兴起 为了方便大规模网站中的管理大量文件,在ASP.NET MVC 2.0版本中引入了一个新概念—区域(Area). 在项目上右击创建新 ...
- 从零开始,搭建博客系统MVC5+EF6搭建框架(4)下,前后台布局实现、发布博客以及展示。
一.博客系统进度回顾 目前已经完成了,前台展示,以及后台发布的功能,最近都在做这个,其实我在国庆的时候就可以弄完的,但是每天自己弄,突然最后国庆2天,连电脑都不想碰,所以就一直拖着,上一篇写了前端实现 ...
随机推荐
- 6个常见的 PHP 安全性攻击
了解常见的PHP应用程序安全威胁,可以确保你的PHP应用程序不受攻击.因此,本文将列出 6个常见的 PHP 安全性攻击,欢迎大家来阅读和学习. 1.SQL注入 SQL注入是一种恶意攻击,用户利用在表单 ...
- Linux内存初始化
start_kernel -> setup_arch 在这个函数中我们主要看这几个函数. machine_specific_memory_setup max_low_pfn = setup_me ...
- 【HDOJ】2062 Subset sequence
这道题目非常好,饶了点儿圈子.我的思路是,先按照组排列.例如,1 2 31 2 2 1 3 11 2 3 2 1 3 ...
- 查找Form的文件名
我们经常会要在ORACLE EBS中寻找我们正在浏览的form页面的执行文件,我们都会直接在Help中的菜单里点击"About Oracle Application",然后查看当前 ...
- lnmp.org一键安装包
LNMP安装快速导航:LNMP安装提示,LNMP安装教程.安装失败处理.虚拟主机管理.可选组件.LNMP文件目录说明.状态管理. 系统需求: CentOS/Debian/Ubuntu Linux系统 ...
- bzoj3165 1568
1568是3165的弱化版,发的代码是3165的这道题完全没想出来,是看wyl大神的题解http://hi.baidu.com/wyl8899/item/2deafd3a376ef2d46d15e99 ...
- 虚拟主机apache
1.虚拟主机配置 windows: 1)加载配置虚拟主机的配置文件,在Apache/conf中找到httpd.conf文件,并搜索出以下的两句话,将Include conf/extra/httpd-v ...
- zookeeper服务器端管理工具
zookeeper基本是基于API和console进行znode的操作,并没有一个比较方便的操作界面,这里也发现了taobao 伯岩写的一个工具,可以比较方便的查询zookeeper信息. 工具的开发 ...
- [摘]selenium-ide编辑命令
----//编辑命令 selenium为我们录制的脚本不是100%符合我们的需求的,所以,编辑录制的脚本是必不可少的工作. 1. 编辑一行命令或注释. 在Table标签下选中某一行命令,命令由com ...
- iPhone 崩溃日志解析
方法一.在编译时保留xx.app, xx.app.dSYM在/user目录下,xcode->orgernize->Device Logs就能够自动部分定位地址 方法二.xcode 有自带的 ...