Razor语法示例

本章通过示例来说明常见用途下的Razor语法。

1.Razor中的核心转换符号是@。这个单一字符用做标记-代码的转换字符,有时也反过来用作代码-标记的转换字符。这里共有两种基本类型的转换:代码表达式和代码块。求出表达式的值,然后将值写入到响应中。

@{

string rootNamespace = "MyApp";

}

<span>@rootNamespace.Models</span>

在这个示例中想要的输出结果是:

<span>MyApp.Models</span>

然而,这样会提示string没有Models属性。这种情况下,Razor是不能理解我们的意图的,Razor支持将表达式用圆括号括起来以支持显示代码表达式:

<span>@(rootNamespace).Models</span>

这样就告知了Razor,.Models是字面量文本,而不是表达式的一部分。

同时Razor支持使用@@来转义@符号,

如<p>You should follow @@aspnet</p>  输出效果为:You should follow @aspnet

2.HTML编码

因为在许多情况下都需要用视图显示用户输入,如博客评论或产品评论等,所以总是存在潜在的跨站脚本注入攻击(也称XSS,将在接下来的章节详细介绍).值得一喜的是Razor表达式是用HTML自动编码的。

如果想展示HTML标记,就返回一个System.Web.IHtmlString对象的实例,Razor并不对它进行编码。同时也可以创建一个HTMLString的实例或者使用Html.Raw便捷方法:

@{

string message = "<strong> 这是一个测试!</strong>";

}

<span>@Html.Raw(message)</span>

效果:这是一个测试

3.代码块

Razor在视图中除了支持代码表达式以外,还支持代码块。

@foreach(var item in stuff){ <li>The name is @item.</li> }

这段代码迭代了一个数组,并为数组中的每一项显示了一个列表项元素。

4Razor语法示例

4.1.隐式代码表达式

如前所述,代码表达式将被计算并将值写入到响应中,这就是在视图中显示值得一般原理。

<span>@model.Message</span>

Razor中的隐式代码表达式总是采用HTML编码方式。

4.2显式代码表达式

代码表达式的值将被计算并写入到响应中,这就是在视图中显示值得一般原理。

<span>1+2=@(1+2)</span>

4.3无编码代码表达式

有些情况下,需要显式的渲染一些不应该采用HTML编码的值,这时可以采用html.Raw方法来保证该值不被编码。

<span>@Html.Raw(model.Message)</span>

4.4代码块

不像代码表达式先求得表达式的值,然后再输出到响应,代码块是简单地执行代码部分。这一点对于声明以后要使用到的变量是有帮助的。

@{

int x = 123;

string y = "because.";

}

4.5文本和标记相结合

这个例子显示了在Razor中混用文本和标记的概念,具体如下:

@foreach(var item in items){

<span>Item @item.Name.</span>

}

4.6混合代码和纯文本

Razor查找标签的开始位置以确定何时将代码转换为标记。然而,有时可能想在一个代码块之后立即输出纯文本。

@if(showMessage){

<text>This is plain text</text>

}

@if(showMessage){

@:This is plain text.

}

Razor 可采用两种不同的方式来混合代码和纯文本。第一种是使用<text>标签,这样只是把标签内容写入到响应中,而标签本身则不写入,如果想回转标记,只需要使用一个标签就行了。第二种方式是使用一种特殊的语法,来实现从代码到纯文本的转换,但是每次只能作用于一行文本。

4.7转义代码分隔符

可以用@@来编码@以达到显示@的目的。此外始终都可以选择使用HTML编码来实现。

Razor:The ASp.net Twitter Handle is &#64;aspnet

或 The ASp.net Twitter Handle is @@64;aspnet

4.8服务器端的注释

Razor为注释一块代码和标记提供了美观的语法。

@* This is a multiline server side comment.

@if(showMessage){

<h1>@ViewBag.Message</h1>

All of this is commented out.

}

*@

4.9调用泛型方法

这与显示代码表达式基本没有什么不同。需要注意一点的是:调用泛型方法的代码包含尖括号。书写时需要用圆括号括起来。

@(Html.SomeMethod)<AType>())

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雨中深巷的油纸伞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值