ASP.NET MVC3 “.NET研究”Razor视图引擎-基础语法

  I:ASP.NET MVC3在Visual Studio 2010中的变化

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

  1.ASP.NET MVC3必要的运行环境为.NET 4.0 (想在3.5用MVC3,没门!)。

  2.默认MVC3模板项目已集成

  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 4默认情况下会拒绝所有访问地址以"_"开头的_*.cshtml文档.关于*.cshtml文档,其实他是WebMatrix的一部分,稍后将会详细介绍该以"_"文档的使用说明。

  例如访问 http://localhost:7985/_ViewPage1.cshtml。

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

  -基础-

  所有以 @开头 或 @{ /* 代码体 */ }  (在@与{直接不得添加任何空格) 的部分代码都会被ASP.NET引擎进行处理。在 @{ /*代码体*/ } 内的代码每一行都必须以";"结束,如:


@{
var i = 10;
var y = 20;
}

  而 @xxx 则不需要以";"作为结束符,如:

  @i 输出 10

  @y; 输出 20;

  代码区内字母分大小写。
  字符类型常量必须用""括起例如: @{ string str = "my string"; }。

  -注意-

  如需要在页面输出”@”字符。
  可以使用HTML ASCII编码@
  当然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上海闵行企业网站制作e;' href='http://www.93tj.com'>上海徐汇企业网站制作f='http://www.93tj.com'>上海企业网站制作"color: #0000ff;">>text@i text</p> 将输出 text@i text
<p>text@itext</p> 将输出 text@itext
<p>text @itext</p> 将报错

  如果是输出的是变量的方法名则不需要用@{}括住也可生效如:


<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#默认的/* ... */ -->
@{
/*
多行注释
*/
}

上海网站建设div>

  若在@{ ... }内部使用<!-- -->注释,则会输出到页面之中,如果在<!-- -->内部使用@变量,则会被处理:


@{
<!-- 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同理-->

  到此结束!呼呼。

时间: 2024-10-29 11:08:20

ASP.NET MVC3 “.NET研究”Razor视图引擎-基础语法的相关文章

ASP.NET MVC3 系列教程 - Razor视图引擎基础语法

原文:ASP.NET MVC3 系列教程 - Razor视图引擎基础语法 I:ASP.NET MVC3在Visual Studio 2010中的变化 在VS2010中新建一个MVC3项目可以看出与以往的MVC2发生了很明显的变化 1.ASP.NET MVC3必要的运行环境为.NET 4.0 (想在3.5用MVC3,没门!) 2.默认MVC3模板项目已集成 3.全新的Razor视图引擎 @{ ViewBag.Title = "Home Page"; }   <h2>@View

一起谈.NET技术,ASP.NET MVC3 Razor视图引擎-基础语法

I:ASP.NET MVC3在Visual Studio 2010中的变化 在VS2010中新建一个MVC3项目可以看出与以往的MVC2发生了很明显的变化. 1.ASP.NET MVC3必要的运行环境为.NET 4.0 (想在3.5用MVC3,没门!). 2.默认MVC3模板项目已集成 3.全新的Razor视图引擎 @{ ViewBag.Title = "Home Page";} <h2>@ViewBag.Message</h2><p> To lea

Razor视图引擎-基础语法

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

ASP.NET MVC3 Razor视图引擎-“.NET技术”基础语法

I:ASP.NET MVC3在Visual Studio 2010中的变化 在VS2010中新建一个MVC3项目可以看出与以往的MVC2发生了很明显的变化. 1.ASP.NET MVC3必要的运行环境为.NET 4.0 (想在3.5用MVC3,没门!). 2.默认MVC3模板项目已集成 3.全新的Razor视图引擎 @{ ViewBag.Title = "Home Page";} <h2>@ViewBag.Message</h2><p> To lea

《Pro ASP.NET MVC 3 Framework》学习笔记之七【MVC3 Razor视图引擎的@句法】

继续完成上次提到的第二部分的笔记:Razor视图引擎 1.Razor是什么: Razor是MVC3里面提供的一个新的视图引擎.ASP.NET视图引擎通过寻找包含服务端指令的特殊元素用来处理web页,正如我们早期所注意到的那样,标准的ASPX视图引擎依赖<%和%>元素,这对于我们来说是非常熟悉的.通过Razor,MVC的开发团队引入了一套以@为中心的新句法元素.一般来说,只要我们熟悉了<%%>的语法,对Razor的使用就不会有太大的问题,尽管可能有一些新的规则. 2.Razor的使用

ASP.NET MVC 3和Razor中的@helper 语法

ASP.NET MVC 3支持一项名为"Razor"的新视图引擎选项(除了继续支持/加强现有的.aspx视图引擎外).当编写一个视图模板时,Razor将所需的字符和击键数减少到最小,并保证一个快速.通畅的编码工作流. 与大部分模板的语法不同,在Razor的帮助下,您不需要中断代码编写,仅仅为了在HTML中标注服务器端代码块的开始和结束.代码分析器足够聪明,它能够从你的代码里推断出是否为服务器端代码.这种更加简洁.富有表现力的语法更加干净,输入也更快速,有趣. 今天的博文涵盖了Razor

一起谈.NET技术,ASP.NET MVC 3和Razor中的@helper 语法

ASP.NET MVC 3支持一项名为"Razor"的新视图引擎选项(除了继续支持/加强现有的.aspx视图引擎外).当编写一个视图模板时,Razor将所需的字符和击键数减少到最小,并保证一个快速.通畅的编码工作流. 与大部分模板的语法不同,在Razor的帮助下,您不需要中断代码编写,仅仅为了在HTML中标注服务器端代码块的开始和结束.代码分析器足够聪明,它能够从你的代码里推断出是否为服务器端代码.这种更加简洁.富有表现力的语法更加干净,输入也更快速,有趣. 今天的博文涵盖了Razor

也玩MVC3.“.NET研究”0 Razor自定义视图引擎来修改默认的Views目录结构

刚刚爱上MVC3.0,几个不眠夜的学习越来越有趣.今天随手尝试自定义Mvc3.0的视图引擎,虽然已成功,但是还发现有点小疑问.随手贴出来希望大家指教指教. MVC的视图文件目录被固定/Views目录内,区域视图文件也是被固定在/Areas目录下,出于好奇和对目录名的敏感,尝试修改它.通过reflector找到视图引擎的构造接口类VirtualPathProviderViewEngine 在MVC2.0中,自定义自己的视图引擎,继承它即可,但在3.0中,上海企业网站制作我发现继承它会缺少一个函数.

也玩MVC3.0 Razor自定义视图引擎“.NET技术”来修改默认的Views目录结构

刚刚爱上MVC3.0,几个不眠夜的学习越来越有趣.今天随手尝试自定义Mvc3.0的视图引擎,虽然已成功,但是还发现有点小疑问.随手贴出来希望大家指教指教. MVC的视图文件目录被固定/Views目录内,区域视图文件也是被固定在/Areas目录下,出于好奇和对目录名的敏感,尝试修改它.通过reflector找到视图引擎的构造接口类VirtualPathProviderViewEngine 在MVC2.0中,自定义自己的视图引擎,继承它即可,但在3.0中,我发现继承它会缺少一个函数.再reflect