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(具名坑洞)

3.@helper辅助方法

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

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

4.@functions自定义函数

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

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

5.@using引用参考资料类别

在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>

6.@model引用参考资料型别

        public ActionResult Index()
{
List<User> list = new List<User>();
list.Add(new User() { Name="",Age=});
list.Add(new User() { Name = "", Age = });
list.Add(new User() { Name = "", Age = });
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>
}

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

  1. ASP.net MVC入门及Razor语法

    一.MVC入门: 1.MVC简介 约定大于配置 2.MVC访问流程 csthml模板(razor模板)就是简化HTML的拼接的模板,最终还是生成html给浏览器显示,不能直接访问cshtml文件. 二 ...

  2. ASP.NET Core 5.0 MVC中的 Razor 页面 介绍

    Razor 是一个用于将基于服务器的代码嵌入到网页中的标记语法. Razor语法由 Razor 标记.c # 和 HTML 组成. 通常包含 Razor 的文件的扩展名 cshtml Razor 语法 ...

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

    在如何在 ASP.NET MVC 中集成 AngularJS(1)中,我们介绍了 ASP.NET MVC 捆绑和压缩.应用程序版本自动刷新和工程构建等内容. 下面介绍如何在 ASP.NET MVC 中 ...

  4. 在 ASP.NET MVC 中充分利用 WebGrid (microsoft 官方示例)

    在 ASP.NET MVC 中充分利用 WebGrid https://msdn.microsoft.com/zh-cn/magazine/hh288075.aspx Stuart Leeks 下载代 ...

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

    介绍 当涉及到计算机软件的开发时,我想运用所有的最新技术.例如,前端使用最新的 JavaScript 技术,服务器端使用最新的基于 REST 的 Web API 服务.另外,还有最新的数据库技术.最新 ...

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

    一.前言 在有些项目需求上或许需要根据模板生产静态页面,那么你一样可以用Razor语法去直接解析你的页面从而把解析的页面生成静态页,这样的使用场景很多,不限于生成静态页面,视图引擎为我们提供了模型到视 ...

  7. Asp.net mvc 中View 的呈现(二)

    [toc] 上一节介绍了 Asp.net mvc 中除 ViewResult 外的所有的 ActionResult,这一节介绍 ViewResult. ViewResultBase ViewResul ...

  8. Vue在ASP.NET MVC中的进行前后端的交互

    Vue在ASP.NET MVC中的进行前后端的交互 Preface: 由于最近在研究前端相关的技术,作为前端非常优秀的框架Vue,个人在学习的过程中遇到一些问题,网上相关资料有限,所以在这这里总结一下 ...

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

    一.视图渲染说明 在有些项目需求上或许需要根据模板生产静态页面,那么你一样可以用Razor语法去直接解析你的页面从而把解析的页面生成静态页,这样的使用场景很多,不限于生成静态页面,视图引擎为我们提供了 ...

随机推荐

  1. Windows系统使用putty远程连接DigitalOcean创建的Linux系统(CentOS6.7为例)

    大部分vps提供网站都会在网站上提供一个控制台界面,方便操作远程vps.但是使用起来特别不方便,尤其在一个神奇的国家,打开国外网站都困难,何况还要在网站上不断的操作.这一教程记录如何在Windows系 ...

  2. git 教程(2)--创建版本库

    什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改.删除,Git都能跟踪,以便任何时刻都可以追踪历史,或 ...

  3. Exploiting the Circulant Structure of Tracking-by-Detection with Kernels(二)

    之前给导师汇报时,主要是论文涉及公式的一些推导

  4. OpenCV中对图像进行二值化的关键函数——cvThreshold()。

    函数功能:采用Canny方法对图像进行边缘检测 函数原型: void cvThreshold( const CvArr* src, CvArr* dst, double threshold, doub ...

  5. linux u-boot跟踪方法总结

    拿到一块板子,其中很重要的一项就是看电路图还有Datasheet. 这个真的很重要,首先你要知道cpu的架构是什么,armv7?arvmv5?还是其他的,哪个公司的芯片?是freescale 还是TI ...

  6. Github GUI 托管代码教程

    附录:克隆仓库到本地:git clone https://github.com/chzeze/WeiboHomeCrawl.git

  7. postgresql数据库实用操作

    查模型的列名: select column_name from information_schema.columns  where table_name= 'your_table'; 应用: 1. 给 ...

  8. Border Tree笔记

    最近在学这个东西(当然不是行道树了QAQ..),感觉挺鬼畜的,整个人都不太好了..(特别是鬼畜的sone爷代码与讲稿),感觉他写的并不是普及向算法...?

  9. midi格式

    http://www.ccarh.org/courses/253/handout/smf/

  10. Expression Add Operators

    Given a string that contains only digits 0-9 and a target value, return all possibilities to add bin ...