ASP.NET MVC中的Razor语法

1.Razor的基本语法

@* 多行代码时需要包含在大括号内{}和每句代码后都需要加分号; *@
@{
    ViewBag.Title = "Index";
    ViewBag.Name = "Linq";
    ViewBag.IsOk = false;
    List<string> list = new List<string>() { "11", "22", "33", "44", "55", "66" };
    ViewBag.Description = "<span style=‘font-weight: bold;‘>迷失之牙</span>";
}
@* 单行代码时不需要分号结束 *@
<p>@DateTime.Now</p>

<p>
    名称:@("欢迎," + ViewBag.Name)
    状态:@(ViewBag.IsOk ? "是" : "否")
    @@Linq
</p>

@if (ViewBag.IsOk != null && ViewBag.IsOk)
{
    @:启用
}
else
{
    @:停用
}

@if (ViewBag.IsOk != null && ViewBag.IsOk)
{
    <span>1.启用</span>
}
else
{
    <span>2.停用</span>
}

@if (ViewBag.IsOk != null && ViewBag.IsOk)
{
    <text>
    1234567
    <span>1. 启用</span>
    </text>
}
else
{
    <text>
    1234567
    <span>2. 停用</span>
    </text>
}

<ul>
    @foreach (var item in list)
    {
        <li>@item</li>
    }
</ul>
@* 所有Razor语法输出的变量都会被HTML编码(HTMLEncode)后输出,如果想里面的HTML标签生效要调用Html.Raw方法 *@
@ViewBag.Description
@Html.Raw(ViewBag.Description)

@{
    <h2>混合例子 @(ViewBag.Name)</h2>
    foreach (var item in list)
    {
        <li>@item</li>
    }

}

2.Razor的主板页面框架

2.1 Razor页面执行顺序
Controller回传给ViewResult给MvcHandler之后,MvcHandler会先设法找出对应的检视页面,然后Razor页面执行生命周期
被MvcHandler找到Razor页面会优先执行,然后检查这个View页面是否有Layout属性

2.2 关于_ViewStart
2.2.1/View/_ViewStart.cshtml文件会在/View/目录下任何View被截入前就先被截入,任何与Controller同名的View子目录下也能出现相同的_ViewStart.cshtml如此一来就可以不同的Controller对应不同的_ViewStart.cshtml

2.3 _Layout布局页面
2.3.1 _Layout.cshtml和一般的Razor的检视页面差不多,不同的地方是有2个Razor语法,分别是@RenderBody(预设坑洞)与@RenderSection(具名坑洞)

[email protected]辅助方法

Razor提供了一种很方便的语法,让你可以将View页面中部分内容或部分代码抽取出来,变成一个独立的辅助方法

<p>@ShowTime() </p>
@helper ShowTime()
{
    @DateTime.Now;
}

[email protected]自定义函数

在@helper无法自定义属性,自能单纯地传入参数,然后格式化你想要呈现的样子直接输出。所以Razor还提供@functions自定义函数功能

<p>@ShowTime() </p>
@functions{
public IHtmlString ShowTime()
{
    return  new HtmlString(DateTime.Now.ToString());
}
}

[email protected]引用参考资料类别

在Razor页面里面可以在页面最上方通过@using引用这一个View页面里面会用到的命名空间

@using MvcApplication1.Models
    <pages
        validateRequest="false"
        pageParserFilterType="System.Web.Mvc.ViewTypeParserFilter, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
        pageBaseType="System.Web.Mvc.ViewPage, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"
        userControlBaseType="System.Web.Mvc.ViewUserControl, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35">
      <controls>
        <add assembly="System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" namespace="System.Web.Mvc" tagPrefix="mvc" />
      </controls>
      <namespaces>
        <!--也可以配置在配置文件里面-->
        <add namespace="MvcApplication1.Models"/>
      </namespaces>
    </pages>

[email protected]引用参考资料型别

        public ActionResult Index()
        {
            List<User> list = new List<User>();
            list.Add(new User() { Name="11",Age=11});
            list.Add(new User() { Name = "12", Age = 12 });
            list.Add(new User() { Name = "13", Age = 13 });
            return View(list);
        }
@using MvcApplication1.Models

@{
    var data = (IEnumerable<User>)Model;
}
<ul>
    @foreach (var item in data)
    {
        <li>@item.Name</li>
    }
</ul>
@using MvcApplication1.Models
@model IEnumerable<User>
<ul>
    @foreach (var item in Model)
    {
        <li>@item.Name</li>
    }
</ul>

7.布局页

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>@ViewBag.Title</title>
</head>
<body>
    <div id="header">
        @if (IsSectionDefined("header"))
        {
            @RenderSection("header", false)
        }
        else
        {
            <h1>没有填充@RenderSection("header", false)</h1>
        }
    </div>
    <div>
        @Html.Partial("_LayoutUser")
    </div>
    <div>
        @RenderBody()
    </div>
    <div id="footer">
        @RenderSection("footer",false)
    </div>

</body>
</html>
@{
    ViewBag.Title = "About";
    Layout = "~/Views/Shared/_LayoutTest.cshtml";
}

<h1>我是@RenderBody()</h1>

@section footer {
    <h1>我是@RenderSection("footer",false)</h1>
}
时间: 2024-12-17 18:57:10

ASP.NET MVC中的Razor语法的相关文章

理解ASP.NET MVC中的Razor视图引擎

什么是 Razor ? Razor 是一种允许向网页中嵌入基于服务器的代码(C#)的标记语法,是微软针对ASP.NET MVC推出的模板引擎. C# 的主要 Razor 语法规则 Razor 代码封装于 @{ ... } 中 行内表达式(变量和函数)以 @ 开头 代码语句以分号结尾 字符串由引号包围 C# 代码对大小写敏感 C# 文件的扩展名是 .cshtml <!-- 单行代码块 --> @{ var myMessage = "Hello World"; } <!-

(转)ASP.NET MVC 3和Razor中的@helper 语法

转自:http://kb.cnblogs.com/page/102191/ ASP.NET MVC 3支持一项名为“Razor”的新视图引擎选项(除了继续支持/加强现有的.aspx视图引擎外).当编写一个视图模板时,Razor将所需的字符和击键数减少到最小,并保证一个快速.通畅的编码工作流. 与大部分模板的语法不同,在Razor的帮助下,您不需要中断代码编写,仅仅为了在HTML中标注服务器端代码块的开始和结束.代码分析器足够聪明,它能够从你的代码里推断出是否为服务器端代码.这种更加简洁.富有表现

ASP.NET Core中使用Razor视图引擎渲染视图为字符串

一.前言 在有些项目需求上或许需要根据模板生产静态页面,那么你一样可以用Razor语法去直接解析你的页面从而把解析的页面生成静态页,这样的使用场景很多,不限于生成静态页面,视图引擎为我们提供了模型到视图的代码或文本生成的能力. 本文章中采用的是ASP.NET Core MVC原生的方法:当然我在YOYOFx中也实现了这种视图引擎 ( https://github.com/maxzhang1985/YOYOFx/blob/master/AspNetCore/YOYO.AspNetCore.View

如何在 ASP.NET MVC 中集成 AngularJS(2)

在如何在 ASP.NET MVC 中集成 AngularJS(1)中,我们介绍了 ASP.NET MVC 捆绑和压缩.应用程序版本自动刷新和工程构建等内容. 下面介绍如何在 ASP.NET MVC 中集成 AngularJS 的第二部分. ASP.NET 捆绑和压缩 CSS 和 JavaScript 的捆绑与压缩功能是 ASP.NET MVC 最流行和有效的特性之一.捆绑和压缩降低了 HTTP 请求和有效载荷的大小,结果是可以更快和更好的执行 ASP.NET MVC 的网站.有许多可以减少 CS

(转)Asp.Net Mvc视图引擎Razor介绍

Asp.Net Mvc视图引擎Razor介绍 1.Razor介绍 程序园原创,转载请注明:http://www.kwstu.com/ArticleView/dabaomvc_201408240820545275 1)ASP.NET MVC3 带来了一种新的名为Razor 的视图引擎,提供了下列优点: Razor 的语法简单且清晰,只需要最小化的输入 Razor 容易学习,语法类似于 C# 和 VB Visual Studio 对于 Razor 提供了智能提示和语法着色 Razor 视图不需要允许

在非MVC中使用Razor模板引擎

模板引擎介绍 Razor.Nvelocity.Vtemplate,因为Razor在VS中有自动提示,使用方便有效率. 在非MVC中使用Razor模板引擎 借助于开源的RazorEngine,我们可以在非asp.net mvc项目中使用Razor引擎,甚至在控制台.WinForm项目中都可以使用Razor(自己开发代码生成器) 如何使用Razor 环境搭建: 1,添加引用RazorEngine.dll 2,创建cshtml 新建一个html,改名为cshtml.注意:通过 添加--html页再改成

ASP.NET MVC中使用FluentValidation验证实体

1.FluentValidation介绍 FluentValidation是与ASP.NET DataAnnotataion Attribute验证实体不同的数据验证组件,提供了将实体与验证分离开来的验证方式,同时FluentValidation还提供了表达式链式语法. 2.安装FluentValidation FluentValidation地址:http://fluentvalidation.codeplex.com/ 使用Visual Studio的管理NuGet程序包安装FluentVa

关于 ASP.NET MVC 中的视图生成

在 ASP.NET MVC 中,我们将前端的呈现划分为三个独立的部分来实现,Controller 用来控制用户的操作,View 用来控制呈现的内容,Model 用来表示处理的数据. 从控制器到视图 通常,在 Controller 中,我们定义多个 Action ,每个 Action 的返回类型一般是 ActionResult,在 Action 处理的最后,我们返回对于视图的调用. public ActionResult Index() { return this.View(); } 默认情况下,

ASP.NET MVC 中的路由

普通的路由 在以前版本的ASP.NET MVC里,这些规则会被定义在RouteConfig.cs文件,也有Routing Assistant扩展可以实现基于特性的路由,不过是收费滴,另外还有一个扩展:http://attributerouting.net/ ,也很不错:理论上ASP.NET MVC 中要实现任意的规则URL 应该是没有问题的. 比如配置的酒店详情页路由 //HOTEL DETAIL routes.MapRoute(name: "HotelDetail", url: &q