Razor语法
Posted YZ-M
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Razor语法相关的知识,希望对你有一定的参考价值。
使用Model对象
首先来看Index.cshtml的第一行:@model WebApplication1.Models.ProductModels
Razor语句都是以@为开头的。每个视图(View)都有自己的Model属性(通过@Model调用)。上面这句代码的意思是将本视图的Model属性的类型指向MvcApplication1.Models.ProductModels类型,这就实现了强类型。
视图中的Model属性用于存放控制器(Controller)传递过来的model实例对象(本示例中ProductController通过“return View(myProduct)”传递给Index视图),下面的代码演示了如何调用该model对象:
@model WebApplication1.Models.ProductModels @{ ViewBag.Title = "Index"; } <h2>Index Product</h2> @* Model对象 *@ <h2>@Model.Name</h2> <h2>@Model.Description</h2> |
注意,第一行代码用于声名Model属性类型用的是@model <Model类型名>(小写m),而调用控制器传递过来的Model对象用的是@Model.<属性名>(大写M)。调试运行:
使用表达式
今天是: @DateTime.Now.ToString("yyyy-MM-dd") 现在是北京时间: @DateTime.Now.ToShortTimeString() |
这种使用对象的简单表达式(@DateTime.Now.ToShortTimeString()和@Model.Name),在这我们不防称之为对象表达式。
除了对象表达式,还可以是其他任意的有返回值的表达式,如条件表达式。如下面代码所示:
@(DateTime.Now.Hour < 22 ? "还早,再写一会吧!" : "该睡觉咯!") |
注意,一般使用非对象表达式时都需要用小括号括起来。
使用代码块
和表达式的使用方式一样,Razor语法中也可以使用由{}括起来的单个C#过程控制代码块(如if、switch、for等)。使用方式如下:
@if (Model.Price > 5M) { string test = "买不起!"; <p>@Model.Name <b>太贵了!</b> @test </p> } |
由{}括起来的代码块内可以写任何C#代码,也可以使用任何HTML标签。但需注意的是,当控制语句内只有一句代码时不能像写C#后台代码一样省略大括号。
@{ int num1 = 10; int num2 = 5; int sum = num1 + num2; @(num1+num2); } |
@(code)可以使用@sum输出结果,也可以输出一个像上述表达式的运算结果。
用Razor和html代码混合编写
在Razor中写html代码和html代码中写Razor语句都是可以的;
- 在作用域内如果是以html标签开始则视为文本输出;
- 如果要输出@,则使用@@;
-
如果要输出非html标签和非Razor语句的代码,则用@:,他的作用是相当于在处于html下面编写一样了,如在@:后面可以加上@就是表示Razor语句的变量;如:
@{ var str = "abc"; ////下面会输出:this is a mail:[email protected], this is var: abc,this is [email protected],this is @; @: this is a mail:[email protected], this is var: @str, this is [email protected],this is @@; //下面输出abc @str }
-
使用@:标签在代码块中输出一行不带html标签的文本非常方便,但如果需要在代码块中输出续或不连续的多行纯文本,则使用text标签较为方便,如下代码所示:
@{ <text> 名称:<b>@Model.Name</b><br /> 分类:<b>@Model.Description</b><br /> 价钱:<b>@Model.Price</b><br /> <pre> 测试行一: <a>aaaa</a> 测试行二: @@ [email protected] </pre> </text> } 运行结果:
使用ViewBag与ViewData
上面讲了通过Model对象来从Controller传递数据到View。和Model对象一样,ViewBag对象也可以用来从Controller传递数据到View。
ViewData 是一个字典型的(Dictionary),通过key值读取对应的value;ViewBag是动态类型,作用和ViewData一样,都是用来存储信息,有一些不同的是ViewData是object类型,ViewBag是dynamic类型。
public class ProductController : Controller { // GET: Product public ActionResult Index() { ViewBag.TestString = "ViewBag这是一行测试文字!"; ViewData["MessageViewData"] = "ViewData 测试文字。"; return View(); } } |
ViewBag在View中的使用方式是和Model一样,如下:
ViewBag的使用:@ViewBag.TestString ViewData的使用: @ViewData["MessageViewData"] |
而dynamic型与object型的区别则是在使用时它会自动根据数据类型转换,而object型则需要我们自己去强制转换。
在Controller中:
public ActionResult Index() { string[] items = new string[] { "one", "two", "three" }; ViewBag.Items = items;// viewbag是一个新的dynamic关键字的封装器 ViewData["Items"] = items; return View(); } |
在View中:
@{ <ul> @foreach (dynamic p in ViewBag.Items) { <li>The item is: @p</li> } @foreach (string a in (string[])ViewData["Items"]) { <li>The item is: @a</li> } </ul> } |
以上是关于Razor语法的主要内容,如果未能解决你的问题,请参考以下文章