MVC:@RenderBody,@RenderSection,@RenderPage

一、@RenderBody:

当创建基于布局页面(即母版页如_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,那么可以把它单独呈现出来,为了防止因缺少节而出现异常,可以给RenderSection()提供第2个参数:
@RenderSection("head", false)

@if (IsSectionDefined("head"))
{
@RenderSection("head", false)
}
else
{
<p>SubMenu Section is not defined!</p>
}

四、举例:

<!DOCTYPE html>  
<html>  
<head>  
    <title>@ViewBag.Title</title>  
    <link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />  
    <script src="@Url.Content("~/Scripts/jquery-1.4.4.min.js")" type="text/javascript"></script>  
    @RenderSection("head", required: true)@*View页面自定义特定js/css使用*@  
</head>  
  
<body>  
    @RenderPage("~/Views/Shared/_Header.cshtml")  
    @RenderBody()  
</body>  
</html>  
在子页中使用section:
@section head{
    <script>
        //to do
    </script>
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值