关闭

ASP.NET Razor - C# 和 VB 代码语法

标签: asp.net
268人阅读 评论(0) 收藏 举报
分类:

ASP.NET Razor - C# 和 VB 代码语法


Razor 同时支持 C# (C sharp) 和 VB (Visual Basic)。


主要的 Razor C# 语法规则

  • Razor 代码块包含在 @{ ... } 中
  • 内联表达式(变量和函数)以 @ 开头
  • 代码语句用分号结束
  • 变量使用 var 关键字声明
  • 字符串用引号括起来
  • C# 代码区分大小写
  • C# 文件的扩展名是 .cshtml

C# 实例

<!-- Single statement block -->
@{ var myMessage = "Hello World"; }

<!-- Inline expression or variable -->
<p>The value of myMessage is: @myMessage</p> 

<!-- Multi-statement block -->
@{
var greeting = "Welcome to our site!";
var weekDay = DateTime.Now.DayOfWeek;
var greetingMessage = greeting + " Here in Huston it is: " + weekDay;
}

<p>The greeting is: @greetingMessage</p>



主要的 Razor VB 语法规则

  • Razor 代码块包含在 @Code ... End Code 中
  • 内联表达式(变量和函数)以 @ 开头
  • 变量使用 Dim 关键字声明
  • 字符串用引号括起来
  • VB 代码不区分大小写
  • VB 文件的扩展名是 .vbhtml

实例

<!-- Single statement block --> 
@Code dim myMessage = "Hello World" End Code

<!-- Inline expression or variable --> 
<p>The value of myMessage is: @myMessage</p> 

<!-- Multi-statement block --> 
@Code
dim greeting = "Welcome to our site!" 
dim weekDay = DateTime.Now.DayOfWeek 
dim greetingMessage = greeting & " Here in Huston it is: " & weekDay
End Code
 

<p>The greeting is: @greetingMessage</p>



它是如何工作的?

Razor 是一种将服务器代码嵌入在网页中的简单的编程语法。

Razor 语法是基于 ASP.NET 框架,专门用于创建 Web 应用程序的部分 Microsoft.NET 框架。

Razor 语法支持所有 ASP.NET 的功能,但是使用的是一种简化语法,对初学者而言更容易学习,对专家而言更有效率的。

Razor 网页可以被描述成带以下两种类型内容的 HTML 网页: HTML 内容和 Razor 代码。

当服务器读取页面时,它首先运行 Razor 代码,然后再发送 HTML 页面到浏览器。在服务器上执行的代码能够执行一些在浏览器上不能完成的任务,比如,访问服务器数据库。服务器代码能创建动态的 HTML 内容,然后发送到浏览器。从浏览器上看,服务器代码生成的 HTML 与静态的 HTML 内容没有什么不同。

带 Razor 语法的 ASP.NET 网页有特殊的文件扩展名 cshtml(Razor C#)或者 vbhtml(Razor VB)。


使用对象

服务器编码往往涉及到对象。

"Date" 对象是一个典型的内置的 ASP.NET 对象,但对象也可以是自定义的,一个网页,一个文本框,一个文件,一个数据库记录,等等。

对象有用于执行的方法。一个数据库记录可能有一个 "Save" 方法,一个图像对象可能有一个 "Rotate" 方法,一个电子邮件对象可能有一个 "Send" 方法,等等。
对象也有用于描述各自特点的属性。一个数据库记录可能有 FirstName 和 LastName 属性。

ASP.NET Date 对象有一个 Now 属性(写成 Date.Now),Now 属性有一个 Day 属性(写成 Date.Now.Day)。下面实例演示了如何访问 Data 对象的一些属性:

实例

<table border="1">
<tr>
<th width="100px">Name</th>
<td width="100px">Value</td>
</tr>
<tr>
<td>Day</td><td>@DateTime.Now.Day</td>
</tr>
<tr>
<td>Hour</td><td>@DateTime.Now.Hour</td>
</tr>
<tr>
<td>Minute</td><td>@DateTime.Now.Minute</td>
</tr>
<tr>
<td>Second</td><td>@DateTime.Now.Second</td>
</tr>
</td>
</table>



If 和 Else条件

动态网页的一个重要特点是,您可以根据条件决定做什么。

做到这一点的常用方法是使用 if ... else 语句:

实例

@{
var txt = "";
if(DateTime.Now.Hour > 12)
{txt = "Good Evening";}
else
{txt = "Good Morning";}
}
<html>
<body>
<p>The message is @txt</p>
</body>
</html>



读取用户输入

动态网页的另一个重要特点是,您可以读取用户输入。

输入是通过 Request[] 功能读取的,并且传送输入数据是经过 IsPost 条件判断的:

实例

@{
var totalMessage = "";
if(IsPost)
{
var num1 = Request["text1"];
var num2 = Request["text2"];
var total = num1.AsInt() + num2.AsInt();
totalMessage = "Total = " + total;
}
}

<html>
<body style="background-color: beige; font-family: Verdana, Arial;">
<form action="" method="post">
<p><label for="text1">First Number:</label><br>
<input type="text" name="text1" /></p>
<p><label for="text2">Second Number:</label><br>
<input type="text" name="text2" /></p>
<p><input type="submit" value=" Add " /></p>
</form>
<p>@totalMessage</p>
</body>
</html>

0
0
查看评论

ASP.NET Razor - C# 和 VB 代码语法

Razor 是一种标记语法,可以让您将基于服务器的代码(Visual Basic 和 C#)嵌入到网页中 主要的 Razor C# 语法规则: (1)、Razor 代码块包含在 @{ … } 中 (2)、内联表达式(变量和函数)以 @ 开头 (3)、代码语句用分号结束 (4)、变量使用 va...
  • Jacksoncz
  • Jacksoncz
  • 2017-06-16 16:23
  • 296

[Asp.net MVC]Asp.net MVC5系列——Razor语法

目录 概念 Razor语法 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net MVC5系列——添加视图 [Asp.net MVC]Asp.net MVC5系列——添加模型 [...
  • Litt_J
  • Litt_J
  • 2015-01-06 22:24
  • 1338

ASP.NET MVC学习---(七)Razor视图引擎语法

之前体验过razor视图引擎@符号的威力了吧~ 什么? 你不觉得
  • qq1010885678
  • qq1010885678
  • 2014-08-03 20:41
  • 2070

[翻译]Razor语法(C#)

声明 本文原文引用自:Intro to ASP.NET Web Programming Razor Syntax 本文由赤石俊哉进行翻译,转载请注明出处,若您是原文作者,且认为本文影响到了您,您可以联系我,我会将文章撤销掉。 本人大学僧一名,英语能力有限,如果有翻译错误的地方,还请大...
  • Toshiya14
  • Toshiya14
  • 2015-08-04 16:27
  • 1081

web项目缺少web组件才能与vs一起运行,带razor语法的 asp.net web pages 2.0.0.1

今天做项目时,打开vs2012 时,突然弹出
  • kai161
  • kai161
  • 2014-11-10 14:45
  • 5262

ASP.NET MVC Razor语法

语法一 @{ C#代码 }  这里花括号里面可以写Html标签 语法二 @idName   这里的idName是个C#变量,语法@idName可以直接输出值到页面 语法三:@(值)     这样方便输出标签id 比如: @{ string idName...
  • u011511086
  • u011511086
  • 2016-08-26 17:05
  • 499

Asp.net mvc怎么在razor里写js代码

我试图在Razor里写JS代码,但是不行 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
  • orichisonic
  • orichisonic
  • 2017-03-14 17:43
  • 1645

ASP.NET Razor &#8211; C# 和 VB 代码语法

Razor 同时支持 C# (C sharp) 和 VB (Visual Basic)。 C# 的主要 Razor 语法规则 Razor 代码封装于 @{ … } 中 行内表达式(变量和函数)以 @ 开头 代码语句以分号结尾 字符串由引号包围 C# 代码对大小写敏感 C# 文件的扩展名是...
  • haliluya123a
  • haliluya123a
  • 2017-08-02 13:27
  • 201

Razor视图中的@:和<text>语法

在MVC项目中新建视图的时候默认支持ASPX引擎和Razor引擎,如果选择ASPX引擎,那它跟webform项目中的*.aspx前台页面没区别,如果选择Razor引擎,那我们可以用更少的代码来实现相同的功能(与使用ASPX引擎相比较),我们不用在HTML中明确地标记出服务模块的结束标志,因为Razo...
  • xiaouncle
  • xiaouncle
  • 2016-12-07 17:43
  • 2049

Razor和HtmlHelper的使用意义

Razor和HtmlHelper的使用意义   写这篇文档的目的是为了给初学MVC的同伴们介绍在MVC的View中的两个新概念,能有利于我们更快,更好的开发项目。一个是视图引擎,一个是HtmlHlper。这两个知识都不是新的,知识概念新而已,都是在我们学过的ASPX 和 Html上做了改进...
  • wangyongxia921
  • wangyongxia921
  • 2014-08-23 20:40
  • 4942
    个人资料
    • 访问:29053次
    • 积分:961
    • 等级:
    • 排名:千里之外
    • 原创:62篇
    • 转载:163篇
    • 译文:2篇
    • 评论:2条
    文章存档
    最新评论