体验ASP.NET MVC 3中的Razor特性

1 闲话ASP.NET MVC 3 beta

不知道不觉MVC3更新了好几次了。。。因为一直在弄Silverlight的开发没有时间关注ASP.NET MVC.之前出preview 的时候就看了园子里的一些文章。

但是总觉得"不咋地",依赖注入早就有一套了,全局拦截器也就那么回事。。好像都没有对开发效率有太大的提升。。。(一己之见.目前正在学习MVC3BEAT的DI)。

除了RAZOR...

好吧。 现在开始动手吧!

2开工

2.1目录

体验ASP.NET MVC 3中的Razor特性_第1张图片

在_ViewStart.cshtml中指定

StartPage.Layout 会在程序启动时,预先加载这个页面。

  
  
  
  
  1. @{
  2. Layout = "~/Views/Shared/_Layout.cshtml";
  3. }

2.2实现框架页

_Layout.cshtml中

  
  
  
  
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>@View.Title</title>
  5. <link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
  6. </head>
  7. <body>
  8. @*模板页*@
  9. <div>
  10. <fieldset>
  11. <legend>Main</legend>
  12. @RenderBody()
  13. </fieldset>
  14. <fieldset>
  15. <legend>底部footer</legend>
  16. @RenderSection("footer" );
  17. </fieldset>
  18. </div>
  19. </body>
  20. </html>

@RenderBody() 呈现主体。

@RenderSection("footer" ); 呈现部分:如底部的版权。

在Index.cshtml中

  
  
  
  
  1. @section footer{
  2. copyrght@@facingwaller
  3. }

2.3显示 view里的变量和显示control里的变量

显示页面里定义的

显示控制器

control里的定义: 

体验ASP.NET MVC 3中的Razor特性_第2张图片

view中的显示

2.4其他一些常用写法

VIEW中

  
  
  
  
  1. <fieldset>
  2. 页面上的变量 use view variable: @@variable=@variable
  3. <br />
  4. 来自控制器的 use Controller variable:@View.variable
  5. <br />
  6. 循环嵌套HTML Loops and Nested HTML Sample
  7. @foreach (var p in words) {
  8. <big>@p ..</big>
  9. }
  10. <br />
  11. 使用if else
  12. @if (IsTrue) {
  13. <b>@@IsTrue is @IsTrue</b>
  14. } else {
  15. <b>@@IsTrue is @IsTrue</b>
  16. }
  17. <br />
  18. 多行代码
  19. @{
  20. var number = 1;
  21. var num2 = 2;
  22. }
  23. Multi-Token Statements 变量和字符串拼凑的语句 @(number + "number is " + number);
  24. <br />
  25. HTML Encoding
  26. <br />
  27. @*以下没弄懂-望指教*@
  28. @if (true) {
  29. <text>
  30. hi it's razor<br />
  31. follow me ! I'm facingwaller
  32. </text>
  33. <br />
  34. <span>hi it's razor<br />
  35. follow me ! I'm facingwaller </span>
  36. } else {
  37. }
  38. <br />
  39. Declarative HTML Helpers声明帮助方法
  40. @helper WordInText(string text) {
  41. foreach (var p in text) {
  42. <li>@p </li>
  43. }
  44. }
  45. 调用 @WordInText("ender")
  46. </fieldset>

最终效果

3激动人心的RAZOR

尝鲜RAZOR这个页面引擎,感觉挺不错。

1 用@ 代替 该死的<% %>显然<,%,>都是非常难敲到的键位。

2 单行的@+变量的方式更加简洁。

3 提供了静态大量的helper方法。

4 其Chart和grid的辅助方法让图表和表格更加容易生成比之前的contrib开源的那个表格生产类库更加来得人性化。

WebImage帮助创建图像,也包括基本的图像操作方法。这些以后我会继续体验和比较然后和大家分享。。。 

4 欢迎讨论其他的页面引擎

还有话要说。目前我还没有看过RAZOR的源码也没有体验过其他的(除了webpages)页面引擎。

说的不好的地方请大家帮指出,也欢迎大家说说其他的页面引擎,特别是说说易用性,设计思想,开发效率和性能,让偶开开眼界。

相关源代码下载请点这里

原文链接:http://www.cnblogs.com/facingwaller/archive/2010/12/04/first_time_to_use_razor_in_mvc3.html

你可能感兴趣的:(体验ASP.NET MVC 3中的Razor特性)