Razor语法

在VS2010中新建一个MVC3项目可以看出与以往的MVC2发生了很明显的变化
image

1.ASP.NET MVC3必要的运行环境为.NET 4.0 (想在3.5用MVC3,没门!)
2.默认MVC3模板项目已集成

image

3.全新的Razor视图引擎
@{
    ViewBag.Title = "Home Page";
}
 
<h2>@ViewBag.Message</h2>
<p>
    To learn more about ASP.NET MVC visit 
    <a href="http://asp.net/mvc" title="ASP.NET MVC Website">
        http://asp.net/mvc
    </a>.
    @ServerInfo.GetHtml()
</p>
4. 关于所有带"_"开头的文档

ASP.NET MVC3默认情况下会拒绝所有访问地址以"_"开头的_*.cshtml文档.关于_*.cshtml文档,其实他是WebPages中的一部分,稍后将会详细介绍该以"_"文档的使用说明.
例如访问 http://localhost:7985/_ViewPage1.cshtml
image

II:Razor视图引擎-基础语法

-基础-

所有以 @开头 或 @{ }  (在@与{直接不得添加任何空格) 的部分代码都会被ASP.NET引擎进行处理.
在 @{ } 内的代码每一行都必须以";"结束,如
@{
    var i = 10;
    var y = 20;
}
而 @xxx 则不需要以";"作为结束符,如 
@i 输出 10
@y; 输出 20;
代码区内字母分大小写.
字符类型常量必须用""括起例如: @{ string str = "my string"; }
-注意-

如需要在页面输出”@”字符
可以使用HTML ASCII编码&#64;
当然Razor也提供智能分析功能: 如果在@的前一个字符若是非空白字符,则ASP.NET不会对其进行处理 
如:<p>text@i xx</p> 输出 text@i xx

单行语法:
@{ var I = 10; }
多行语法:

@{ 
    var I = 10;
    Var y = 20;
}

1. 使用局部变量,Razor不支持访问修饰符(public,private等,这个没任何意义)
在单行上定义局部变量
@{ var total = 7; }
@{ var myMessage = "Hello World";}
在多行上定义局部变量

@{
    var greeting = "Welcome to our site!";
    var weekDay = DateTime.Now.DayOfWeek;
    var greetingMessage = greeting + " Today is: " + weekDay;
}


在上下文中使用变量

<p>The value of your account is: @total </p>
<p>The value of myMessage is: @myMessage</p>


注意
:变量拼接输出
@{ var i = 10; }
<p>text @i text</p> 将输出 text 10 text
但是如果你想要输出 text10text 呢?

<p>text@{@i}text</p>即可
<p>text@i text</p> 将输出 text@i text
<p>text@itext</p> 将输出 text@itext
<p>text @itext</p> 将报错

如果是输出的是变量的方法名则不需要用@{}括住也可生效,但注意在@字符前记得加空格(感谢spook指出)如:
<p>text @i.ToString()text</p>
使用变量对象可直接写: @var1 @var2 @myObject.xx

2. 使用逻辑处理

@{
    if (xx)
    {
    //do something
    }
    else
    {
    //do anything
    }
}

3. 在@{... }内部使用html标记

@{
    <p>text</P>
    <div>div1</div>
}

4. 在@{...}内部输出文本
利用@:进行单行输出:

@{
    @:This is some text
    @:This is text too
    @:@i 也可输出变量
}

利用<text />进行多行输出:

@{
    <text>
        tomorrow is good
        some girl is nice
    </text>
}

5. 在@{...}内部使用注释

@{
    //单行注释
    var i = 10;
    //defg
}
 
    @* 多行注释 *@
    @* 
        多行注释
        多行注释 
    *@
 
 
@{
    @*
        多行注释
        多行注释 
    *@
    var i = 10;  @* asdfasf *@
}
 
<!-- 同时也可以使用C#默认的 -->
 
@{
    
}

若在@{ ... }内部使用<!-- -->注释,则会输出到页面之中,如果在<!-- -->内部使用@变量,则会被处理
@{
<!-- time now: @DateTime.Now.ToString() -->
}
输出: <!-- time now: 4/9/2011 12:01 -->>

6. 类型转换
AsInt(), IsInt()
AsBool(),IsBool()
AsFloat(),IsFloat()
AsDecimal(),IsDecimal()
AsDateTime(),IsDateTime()
ToString()
例子:

@{
    var i = “10”;
}
 
<p> i = @i.AsInt() </p> <!-- 输出 i = 10 --> 

7. 使用循环

<!--方式1-->
@for (int i = 10; i < 11; i++)
{
    @:@i
}
<!--方式2-->
@{
    for (int i = 10; i < 11; i++)
    {
        //do something
    }
}
 
<!--while同理-->

到此结束!呼呼

声明: 本文版权归 作者和博客园共有,转载必须保留此段声明。
Razor 是一种轻量级且功能强大的视图引擎,广泛用于 ASP.NET MVC 和 ASP.NET Core 中,它允许开发者将 C# 代码与 HTML 标记语言无缝结合,从而生成动态网页内容。以下是对 Razor 语法的全面指南,涵盖基础语法、常用结构以及最佳实践。 ### 3.1 Razor 中的 `@` 符号 `@` 符号是 Razor 的核心语法标记,用于切换 HTML 和 C# 代码的上下文。在 Razor 文件中,遇到 `@` 时,后续内容将被视为 C# 达式或语句。 例如,以下代码将当前日期时间显示在页面上: ```csharp <p>当前时间:@DateTime.Now</p> ``` 如果需要在文本中使用 `@` 符号本身(例如电子邮件地址),可以使用双 `@` 来转义: ```html <p>联系我:example@@domain.com</p> ``` ### 3.2 嵌入 C# 代码块 Razor 允许嵌入多行 C# 代码块,使用 `@{ ... }` 定义。这些代码块可以包含变量声明、条件判断、循环等逻辑。 ```csharp @{ var message = "欢迎使用 Razor"; if (DateTime.Now.Hour < 12) { message += ",上午好!"; } else { message += ",下午好!"; } } <p>@message</p> ``` ### 3.3 条件语句与循环结构 Razor 支持常见的 C# 控制结构,如 `if`、`else`、`for`、`foreach` 等。这些结构无需额外的 `@` 前缀,但需要在 HTML 中正确闭合。 ```csharp @if (DateTime.Now.DayOfWeek == DayOfWeek.Saturday) { <p>今天是周末!</p> } else { <p>今天是工作日。</p> } <ul> @foreach (var item in new[] { "苹果", "香蕉", "橙子" }) { <li>@item</li> } </ul> ``` ### 3.4 模型绑定与强类型视图 Razor 支持通过 `@model` 指令绑定模型对象,从而实现强类型视图。这样可以在视图中访问模型属性并进行类型检查。 ```csharp @model MyProject.Models.Product <p>产品名称:@Model.Name</p> <p>价格:@Model.Price.ToString("C")</p> ``` ### 3.5 布局页与部分视图 Razor 支持布局页(Layout)和部分视图(Partial Views),以实现页面结构的复用和模块化。 - **布局页**:通常定义为 `_Layout.cshtml`,并通过 `@RenderBody()` 指定内容插入点。 ```csharp <!DOCTYPE html> <html> <head> <title>@ViewBag.Title</title> </head> <body> <header>公共头部</header> <main> @RenderBody() </main> <footer>公共底部</footer> </body> </html> ``` - **视图中使用布局**: ```csharp @{ Layout = "_Layout"; } <h1>首页内容</h1> ``` - **部分视图**:通过 `@await Html.PartialAsync("_PartialViewName")` 引入。 ### 3.6 单与 HTML 辅助方法 Razor 提供了丰富的 HTML 辅助方法,用于生成单、链接、标签等。这些方法通常以 `@Html.` 开头。 ```csharp @using (Html.BeginForm("ActionName", "ControllerName", FormMethod.Post)) { @Html.Label("username", "用户名") @Html.TextBox("username") <input type="submit" value="提交" /> } ``` ### 3.7 JavaScript 与 Razor 的结合 在 Razor 页面中,可以将 C# 变量传递给 JavaScript,实现动态脚本逻辑。 ```csharp <script> var serverTime = "@DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")"; console.log("服务器时间:" + serverTime); </script> ``` ### 3.8 Razor 语法重构与迁移建议 在某些情况下,例如将旧的 WebForms 视图迁移到 Razor 或进行跨平台迁移时,可能需要对现有代码进行重构。建议手动检查服务器端脚本,并将其转换为客户端 JavaScript 或视图模型逻辑[^2]。对于复杂逻辑,可参考官方文档或社区资源获取迁移方案。 ### 3.9 使用 DevExtreme 等第三方控件库 在 ASP.NET Core 项目中,可结合 DevExtreme 等现代 UI 控件库,提升界面交互体验。DevExtreme 提供了丰富的 HTML5/JavaScript 小部件,如数据网格、图、编辑器等,支持 Razor 语法集成[^3]。 例如,使用 DevExtreme 的数据网格控件: ```csharp @using DevExtreme.AspNet.Mvc @(Html.DevExtreme().DataGrid() .ID("grid") .DataSource(d => d.WebApi().Controller("Products")) .Columns(columns => { columns.Add().DataField("Name"); columns.Add().DataField("Price"); }) ) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值