`
qqjavagood
  • 浏览: 95349 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

Razor view engine 基础语法

阅读更多

          在asp.net MVC3中,引入了razor view engine , 更加方便,快捷的进行页面开发。

下面是razor的简单的语法信息:

一下文章转载自:http://www.cnblogs.com/highend/archive/2011/04/09/aspnet_mvc3_razor_engine.html


 

 <span>所有以 @开头 或 @{ /* 代码体 */ }  (在@与{直接不得添加任何空格) 的部分代码都会被ASP.NET引擎进行处理.</span>


在 @{ /*代码体*/ } 内的代码每一行都必须以";"结束,如<br style="padding: 0px; margin: 0px;">
@{<br style="padding: 0px; margin: 0px;">
    var i = 10;<br style="padding: 0px; margin: 0px;">
    var y = 20;<br style="padding: 0px; margin: 0px;">
}<br style="padding: 0px; margin: 0px;">
而 @xxx 则不需要以";"作为结束符,如 <br style="padding: 0px; margin: 0px;">
@i 输出 10<br style="padding: 0px; margin: 0px;">
@y; 输出 20;<br style="padding: 0px; margin: 0px;"><strong style="padding: 0px; margin: 0px;"><span style="padding: 0px; margin: 0px; color: #ff0000;">代码区内字母分大小写.<br style="padding: 0px; margin: 0px;"></span>
</strong>
字符类型常量必须用""括起例如: @{ string str = "my string"; }<br style="padding: 0px; margin: 0px;"><strong style="padding: 0px; margin: 0px;">-注意-</strong>


如需要在页面输出”@”字符<br style="padding: 0px; margin: 0px;">
可以使用HTML ASCII编码&amp;#64;<br style="padding: 0px; margin: 0px;">
当然Razor也提供智能分析功能: 如果在@的前一个字符若是非空白字符,则ASP.NET不会对其进行处理 <br style="padding: 0px; margin: 0px;">
如:<p>text@i xx</p> 输出 text@i xx<br style="padding: 0px; margin: 0px;"><br style="padding: 0px; margin: 0px;">
单行语法:<br style="padding: 0px; margin: 0px;">
@{ var I = 10; }<br style="padding: 0px; margin: 0px;">
多行语法:

<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 650px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 650px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">

<pre>    var I = 10;</pre>
<pre>    Var y = 20;</pre>
<pre>}</pre>


<p class="t">1. 使用局部变量,Razor不支持访问修饰符(public,private等,这个没任何意义)<br style="padding: 0px; margin: 0px;">
在单行上定义局部变量<br style="padding: 0px; margin: 0px;">
@{ var total = 7; }<br style="padding: 0px; margin: 0px;">
@{ var myMessage = "Hello World";}<br style="padding: 0px; margin: 0px;">
在多行上定义局部变量
<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 650px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 650px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">

<pre>    var greeting = "Welcome to our site!";</pre>
<pre>    var weekDay = DateTime.Now.DayOfWeek;</pre>
<pre>    var greetingMessage = greeting + " Today is: " + weekDay;</pre>
<pre>}</pre>


<br style="padding: 0px; margin: 0px;">
在上下文中使用变量

<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 675px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">
<pre><span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
The value of your account is: @total <span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
</pre>
<pre><span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
The value of myMessage is: @myMessage<span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
</pre>


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

<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 675px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">
<pre><span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
text@{@i}text<span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
即可</pre>
<pre><span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
text@i text<span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
将输出 text@i text</pre>
<pre><span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
text@itext<span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
将输出 text@itext</pre>
<pre><span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
text @itext<span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
将报错</pre>


<p class="t">如果是输出的是变量的方法名则不需要用@{}括住也可生效,<span style="padding: 0px; margin: 0px; color: #ff0000;">但注意在@字符前记得加空格</span>
如:<br style="padding: 0px; margin: 0px;">
<p>text @i.ToString()text</p><br style="padding: 0px; margin: 0px;">
使用变量对象可直接写: @var1 @var2 @myObject.xx

<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 675px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">
<pre>@{</pre>
<pre>    if (xx)</pre>
<pre>    {</pre>
<pre>    //do something</pre>
<pre>    }</pre>
<pre>    else</pre>
<pre>    {</pre>
<pre>    //do anything</pre>
<pre>    }</pre>
<pre>}</pre>


<p class="t">3. 在@{... }内部使用html标记
<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 675px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">

<pre>    <span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
text<span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">P</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
</pre>
<pre>    <span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">div</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
div1<span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">div</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
</pre>
<pre>}</pre>


<p class="t">4. 在@{...}内部输出文本<br style="padding: 0px; margin: 0px;">
利用@:进行单行输出:
<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 675px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">

<pre>    @:This is some text</pre>
<pre>    @:This is text too</pre>
<pre>    @:@i 也可输出变量</pre>
<pre>}</pre>


<p class="t">利用<text />进行多行输出:
<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 675px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">

<pre>    <span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">text</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
</pre>
<pre>        tomorrow is good</pre>
<pre>        some girl is nice</pre>
<pre>    <span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">text</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
</pre>
<pre>}</pre>


<p class="t">5. 在@{...}内部使用注释
<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 658px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">

<pre>    //单行注释</pre>
<pre>    var i = 10;</pre>
<pre>    //defg</pre>
<pre>}</pre>
<pre> </pre>
<pre>    @* 多行注释 *@</pre>
<pre>    @* </pre>
<pre>        多行注释</pre>
<pre>        多行注释 </pre>
<pre>    *@</pre>
<pre> </pre>
<pre> </pre>
<pre>@{</pre>
<pre>    @*</pre>
<pre>        多行注释</pre>
<pre>        多行注释 </pre>
<pre>    *@</pre>
<pre>    var i = 10;  @* asdfasf *@</pre>
<pre>}</pre>
<pre> </pre>
<pre><span style="padding: 0px; margin: 0px; color: #008000;"><!-- 同时也可以使用C#默认的/* ... */ --></span>
</pre>
<pre> </pre>
<pre>@{</pre>
<pre>    /*</pre>
<pre>        多行注释 </pre>
<pre>    */</pre>
<pre>}</pre>


<p class="t">若在@{ ... }内部使用<!-- -->注释,则会输出到页面之中,如果在<!-- -->内部使用@变量,则会被处理<br style="padding: 0px; margin: 0px;">
@{<br style="padding: 0px; margin: 0px;">
<!-- time now: @DateTime.Now.ToString() --><br style="padding: 0px; margin: 0px;">
}<br style="padding: 0px; margin: 0px;">
输出: <!-- time now: 4/9/2011 12:01 -->>

AsInt(), IsInt()<br style="padding: 0px; margin: 0px;">
AsBool(),IsBool()<br style="padding: 0px; margin: 0px;">
AsFloat(),IsFloat()<br style="padding: 0px; margin: 0px;">
AsDecimal(),IsDecimal()<br style="padding: 0px; margin: 0px;">
AsDateTime(),IsDateTime()<br style="padding: 0px; margin: 0px;">
ToString()<br style="padding: 0px; margin: 0px;">
例子:
<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 675px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">

<pre>    var i = “10”;</pre>
<pre>}</pre>
<pre> </pre>
<pre><span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
i = @i.AsInt() <span style="padding: 0px; margin: 0px; color: #0000ff;"></</span>
<span style="padding: 0px; margin: 0px; color: #800000;">p</span>
<span style="padding: 0px; margin: 0px; color: #0000ff;">></span>
<span style="padding: 0px; margin: 0px; color: #008000;"><!-- 输出 i = 10 --></span>
</pre>


<p class="t">7. 使用循环
<div id="codeSnippetWrapper" style="margin-top: 20px; margin-right: 0px; margin-bottom: 10px; margin-left: 0px; font-size: 8pt; text-align: left; background-color: #f4f4f4; line-height: 12pt; width: 675px; font-family: 'Courier New', courier, monospace; direction: ltr; cursor: text; padding: 4px; border: 1px solid silver;">
<div id="codeSnippet" style="line-height: 12pt; width: 658px; direction: ltr; font-size: 8pt; border-style: none; padding: 0px; margin: 0px;">
<pre><span style="padding: 0px; margin: 0px; color: #008000;"><!--方式1--></span>
</pre>
<pre>@for (int i = 10; i <span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
11; i++)</pre>
<pre>{</pre>
<pre>    @:@i</pre>
<pre>}</pre>
<pre><span style="padding: 0px; margin: 0px; color: #008000;"><!--方式2--></span>
</pre>
<pre>@{</pre>
<pre>    for (int i = 10; i <span style="padding: 0px; margin: 0px; color: #0000ff;"><</span>
11; i++)</pre>
<pre>    {</pre>
<pre>        //do something</pre>
<pre>    }</pre>
<pre>}</pre>
<pre> </pre>


 
0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics