Razor语法:RenderBody、RenderPage、RenderSection

RenderBody

在Razor引擎中没有了“母版页”,取而代之的是叫做“布局”的页面(_Layout.cshtml)放在了共享视图文件夹中。在这个页面中,会看到<body>标签里有这样一条语句:

@RenderBody()

其实它的作用和母版页中的<contentplaceholder>服务器控件类似,当创建基于此布局页面的视图时,视图的内容会和布局页面合并,而新创建视图的内容会通过布局页面的@RenderBody()方法呈现在<body>标签之间。

这个方法不需要参数,而且只能出现一次。

RenderPage

从名称可以猜出来这个方法是要呈现一个页面。比如网页中固定的头部可以单独放在一个共享的视图文件中,然后在布局页面中通过这个方法调用,用法如下:

@RenderPage(“~/Views/Shared/_Header.cshtml”)

@RenderBody()

代码简洁直观,另外似乎带下划线的视图文件有特殊含义,以后再研究吧。

RenderSection

布局页面还有节(Section)的概念,用于单独呈现视图模板中定义的一个节,用法如下:

@RenderPage(“~/Views/Shared/_Header.cshtml”)

@RenderBody()

@RenderSection(“footer”)

当然还要在视图中定义节,否则会出现异常:

@section footer {

    <b>Footer Here</b>

}

为了防止因缺少节而出现异常,可以给RenderSection()提供第2个参数:

@RenderSection(“footer”, false)

参考资料

http://blog.sina.com.cn/s/blog_55e55fcb0100oc8b.html

http://www.dotnetcurry.com/ShowArticle.aspx?ID=636

MVC 中Html.RenderPartial与Html.RenderAction 和 Html.Partial 区别

Html.Partial是将视图内容直接生成一个字符串并返回

Html.RenderPartial方法是直接输出至当前HttpContext

Html.RenderAction调用一下Action再重新執行一次Controller → Model → View的順序

 它们在视图中的使用方式是不同的:

<%Html.RenderPartial("MyPartialView");%>

<%Html.RenderAction("MyPartialView");%> 

<%=Html.Partial("MyPartialView")%> (相当于一个字符串)

注意:RenderPartial以<%开头,末尾有分号。而Partial,RenderAction以<%=开头,末尾没有分号。

这里RenderPartial,RenderAction 方法不是返回一个字符串,而是直接输出内容到调用视图模板的输出流中。 方法后使用分号,否则会导致编译器错误。这是因为<% %>代码块是一串代码语句,在C#代码中,需要通过分号标识语句结束。

转载于:https://www.cnblogs.com/sunshch/archive/2012/12/07/2807419.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Razor语法是一种用于ASP.NET Web应用程序的视图引擎,允许开发人员通过混合C#代码和HTML标记来创建动态Web页面。以下是Razor语法的详细教程: 1. Razor语法中的代码块用@符号包围,如@{ }。这些代码块可以包含任何C#代码。 2. Razor语法中的表达式用@符号和小括号包围,如@( )。表达式可以是任何C#表达式,并且可以在HTML标记中嵌套使用。 3. Razor语法中的注释用@*和*@包围,如@* 这是一个注释 *@。 4. Razor语法中的条件语句可以使用if、else if和else关键字。例如: ``` @if (condition) { // do something } else if (condition2) { // do something else } else { // do something else } ``` 5. Razor语法中的循环语句可以使用for、foreach和while关键字。例如: ``` @for (int i = 0; i < 10; i++) { <p>@i</p> } @foreach (var item in collection) { <p>@item</p> } @while (condition) { // do something } ``` 6. Razor语法中的HTML标记可以直接嵌套在代码块中,如: ``` @{ var name = "John"; } <h1>Hello, @name!</h1> ``` 7. Razor语法中的HTML标记可以使用@符号和小括号来嵌套表达式,如: ``` <h1>@("Hello, " + name + "!")</h1> ``` 8. Razor语法中的HTML标记可以使用@符号和大括号来嵌套代码块,如: ``` @if (condition) { <p>Some text</p> } ``` 9. Razor语法中的HTML标记可以使用属性,如: ``` <a href="@Url.Action("Index", "Home")">Home</a> ``` 以上就是Razor语法的详细教程,希望能对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值