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

2020-12-13 05:56

阅读:336

标签:des   style   blog   class   c   code   

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

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

在VS2010中新建一个MVC3项目可以看出与以往的MVC2发生了很明显的变化
soscw.com,搜素材

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

soscw.com,搜素材

3.全新的Razor视图引擎
@{
    ViewBag.Title = "Home Page";
}
 
h2>@ViewBag.Messageh2>
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
soscw.com,搜素材

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

-基础-

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

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

text@i xx

输出 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: @myMessagep>


注意
:变量拼接输出
@{ var i = 10; }
text @i text

将输出 text 10 text
但是如果你想要输出 text10text 呢?
p>text@{@i}textp>即可
p>text@i textp> 将输出 text@i text
p>text@itextp> 将输出 text@itext
p>text @itextp> 将报错

如果是输出的是变量的方法名则不需要用@{}括住也可生效,但注意在@字符前记得加空格(感谢spook指出)如:

text @i.ToString()text


使用变量对象可直接写: @var1 @var2 @myObject.xx

2. 使用逻辑处理

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

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

@{
    p>textP>
    div>div1div>
}

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

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

利用进行多行输出:

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

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

@{
    //单行注释
    var i = 10;
    //defg
}
 
    @* 多行注释 *@
    @* 
        多行注释
        多行注释 
    *@
 
 
@{
    @*
        多行注释
        多行注释 
    *@
    var i = 10;  @* asdfasf *@
}
 
 
@{
    /*
        多行注释 
    */
}

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

}
输出: >

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

@{
    var i = “10”;
}
 
p> i = @i.AsInt() p>  

7. 使用循环

@for (int i = 10; i  11; i++)
{
    @:@i
}
@{
    for (int i = 10; i  11; i++)
    {
        //do something
    }
}
 

到此结束!呼呼

ASP.NET MVC3 系列教程 - Razor视图引擎基础语法,搜素材,soscw.com

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

标签:des   style   blog   class   c   code   

原文地址:http://www.cnblogs.com/lonelyxmas/p/3738917.html


评论


亲,登录后才可以留言!