--- title: Razor Syntax Reference | Microsoft Docs author: rick-anderson description: keywords: ASP.NET Core, ms.author: riande manager: wpickett ms.date: 10/14/2016 ms.topic: article ms.assetid: a89a8433-8b0e-4795-a73a-82114d27e233 ms.technology: aspnet ms.prod: aspnet-core uid: mvc/views/razor --- # Razor Syntax Reference [Taylor Mullen](https://twitter.com/ntaylormullen) and [Rick Anderson](https://twitter.com/RickAndMSFT) ## What is Razor? Razor is a markup syntax for embedding server based code into web pages. The Razor syntax consists of Razor markup, C# and HTML. Files containing Razor generally have a *.cshtml* file extension. ## Rendering HTML The default Razor language is HTML. Rendering HTML from Razor is no different than in an HTML file. A Razor file with the following markup: ```html

Hello World

``` Is rendered unchanged as `

Hello World

` by the server. ## Razor syntax Razor supports C# and uses the `@` symbol to transition from HTML to C#. Razor evaluates C# expressions and renders them in the HTML output. Razor can transition from HTML into C# or into Razor specific markup. When an `@` symbol is followed by a [Razor reserved keyword](#razor-reserved-keywords) it transitions into Razor specific markup, otherwise it transitions into plain C# . HTML containing `@` symbols may need to be escaped with a second `@` symbol. For example: ```html

@@Username

``` would render the following HTML: ```html

@Username

``` HTML attributes and content containing email addresses don’t treat the `@` symbol as a transition character. `Support@contoso.com` ## Implicit Razor expressions Implicit Razor expressions start with `@` followed by C# code. For example: ```html

@DateTime.Now

@DateTime.IsLeapYear(2016)

``` With the exception of the C# `await` keyword implicit expressions must not contain spaces. For example, you can intermingle spaces as long as the C# statement has a clear ending: ```html

@await DoSomething("hello", "world")

``` ## Explicit Razor expressions Explicit Razor expressions consists of an @ symbol with balanced parenthesis. For example, to render last weeks’ time: ```html

Last week this time: @(DateTime.Now - TimeSpan.FromDays(7))

``` Any content within the @() parenthesis is evaluated and rendered to the output. Implicit expressions generally cannot contain spaces. For example, in the code below, one week is not subtracted from the current time: [!code-html[Main](razor/sample/Views/Home/Contact.cshtml?range=20)] Which renders the following HTML: ```html

Last week: 7/7/2016 4:39:52 PM - TimeSpan.FromDays(7)

``` You can use an explicit expression to concatenate text with an expression result: ```none @{ var joe = new Person("Joe", 33); }

Age@(joe.Age)

``` Without the explicit expression, `

Age@joe.Age

` would be treated as an email address and `

Age@joe.Age

` would be rendered. When written as an explicit expression, `

Age33

` is rendered. ## Expression encoding C# expressions that evaluate to a string are HTML encoded. C# expressions that evaluate to `IHtmlContent` are rendered directly through *IHtmlContent.WriteTo*. C# expressions that don't evaluate to *IHtmlContent* are converted to a string (by *ToString*) and encoded before they are rendered. For example, the following Razor markup: ```html @("Hello World") ``` Renders this HTML: ```html <span>Hello World</span> ``` Which the browser renders as: `Hello World` `HtmlHelper` `Raw` output is not encoded but rendered as HTML markup. >[!WARNING] > Using `HtmlHelper.Raw` on unsanitized user input is a security risk. User input might contain malicious JavaScript or other exploits. Sanitizing user input is difficult, avoid using `HtmlHelper.Raw` on user input. The following Razor markup: ```html @Html.Raw("Hello World") ``` Renders this HTML: ```html Hello World ``` ## Razor code blocks Razor code blocks start with `@` and are enclosed by `{}`. Unlike expressions, C# code inside code blocks is not rendered. Code blocks and expressions in a Razor page share the same scope and are defined in order (that is, declarations in a code block will be in scope for later code blocks and expressions). ```none @{ var output = "Hello World"; }

The rendered result: @output

``` Would render: ```html

The rendered result: Hello World

``` ### Implicit transitions The default language in a code block is C#, but you can transition back to HTML. HTML within a code block will transition back into rendering HTML: ```none @{ var inCSharp = true;

Now in HTML, was in C# @inCSharp

} ``` ### Explicit delimited transition To define a sub-section of a code block that should render HTML, surround the characters to be rendered with the Razor `` tag: ```none @for (var i = 0; i < people.Length; i++) { var person = people[i]; Name: @person.Name } ``` You generally use this approach when you want to render HTML that is not surrounded by an HTML tag. Without an HTML or Razor tag, you get a Razor runtime error. ### Explicit Line Transition with `@:` To render the rest of an entire line as HTML inside a code block, use the `@:` syntax: ```none @for (var i = 0; i < people.Length; i++) { var person = people[i]; @:Name: @person.Name } ``` Without the `@:` in the code above, you'd get a Razor run time error. ## Control Structures Control structures are an extension of code blocks. All aspects of code blocks (transitioning to markup, inline C#) also apply to the following structures. ### Conditionals `@if`, `else if`, `else` and `@switch` The `@if` family controls when code runs: ```none @if (value % 2 == 0) {

The value was even

} ``` `else` and `else if` don't require the `@` symbol: ```none @if (value % 2 == 0) {

The value was even

} else if (value >= 1337) {

The value is large.

} else {

The value was not large and is odd.

} ``` You can use a switch statement like this: ```none @switch (value) { case 1:

The value is 1!

break; case 1337:

Your number is 1337!

break; default:

Your number was not 1 or 1337.

break; } ``` ### Looping `@for`, `@foreach`, `@while`, and `@do while` You can render templated HTML with looping control statements. For example, to render a list of people: ```none @{ var people = new Person[] { new Person("John", 33), new Person("Doe", 41), }; } ``` You can use any of the following looping statements: `@for` ```none @for (var i = 0; i < people.Length; i++) { var person = people[i];

Name: @person.Name

Age: @person.Age

} ``` `@foreach` ```none @foreach (var person in people) {

Name: @person.Name

Age: @person.Age

} ``` `@while` ```none @{ var i = 0; } @while (i < people.Length) { var person = people[i];

Name: @person.Name

Age: @person.Age

i++; } ``` `@do while` ```none @{ var i = 0; } @do { var person = people[i];

Name: @person.Name

Age: @person.Age

i++; } while (i < people.Length); ``` ### Compound `@using` In C# a using statement is used to ensure an object is disposed. In Razor this same mechanism can be used to create [HTML helpers](html-helpers.md) that contain additional content. For instance, we can utilize [🔧 HTML Helpers](html-helpers.md) to render a form tag with the `@using` statement: ```none @using (Html.BeginForm()) {
email:
} ``` You can also perform scope level actions like the above with [Tag Helpers](tag-helpers/index.md). ### `@try`, `catch`, `finally` Exception handling is similar to C#: [!code-html[Main](razor/sample/Views/Home/Contact7.cshtml)] ### `@lock` Razor has the capability to protect critical sections with lock statements: ```none @lock (SomeLock) { // Do critical section work } ``` ### Comments Razor supports C# and HTML comments. The following markup: ```none @{ /* C# comment. */ // Another C# comment. } ``` Is rendered by the server as: ```none ``` Razor comments are removed by the server before the page is rendered. Razor uses `@* *@` to delimit comments. The following code is commented out, so the server will not render any markup: ```none @* @{ /* C# comment. */ // Another C# comment. } *@ ``` ## Directives Razor directives are represented by implicit expressions with reserved keywords following the `@` symbol. A directive will typically change the way a page is parsed or enable different functionality within your Razor page. Understanding how Razor generates code for a view will make it easier to understand how directives work. A Razor page is used to generate a C# file. For example, this Razor page: [!code-html[Main](razor/sample/Views/Home/Contact8.cshtml)] Generates a class similar to the following: ```csharp public class _Views_Something_cshtml : RazorPage { public override async Task ExecuteAsync() { var output = "Hello World"; WriteLiteral("/r/n
Output: "); Write(output); WriteLiteral("
"); } } ``` [Viewing the Razor C# class generated for a view](#razor-customcompilationservice-label) explains how to view this generated class. ### `@using` The `@using` directive will add the c# `using` directive to the generated razor page: [!code-html[Main](razor/sample/Views/Home/Contact9.cshtml)] ### `@model` The `@model` directive allows you to specify the type of the model passed to your Razor page. It uses the following syntax: ```none @model TypeNameOfModel ``` For example, if you create an ASP.NET Core MVC app with individual user accounts, the *Views/Account/Login.cshtml* Razor view contains the following model declaration: ```csharp @model LoginViewModel ``` In the class example in , the class generated inherits from `RazorPage`. By adding an `@model` you control what’s inherited. For example ```csharp @model LoginViewModel ``` Generates the following class ```csharp public class _Views_Account_Login_cshtml : RazorPage ``` Razor pages expose a `Model` property for accessing the model passed to the page. ```html
The Login Email: @Model.Email
``` The `@model` directive specified the type of this property (by specifying the `T` in `RazorPage` that the generated class for your page derives from). If you don't specify the `@model` directive the `Model` property will be of type `dynamic`. The value of the model is passed from the controller to the view. See [Strongly typed models and the @model keyword](../../tutorials/first-mvc-app/adding-model.md#strongly-typed-models-keyword-label) for more information. ### `@inherits` The `@inherits` directive gives you full control of the class your Razor page inherits: ```none @inherits TypeNameOfClassToInheritFrom ``` For instance, let’s say we had the following custom Razor page type: [!code-csharp[Main](razor/sample/Classes/CustomRazorPage.cs)] The following Razor would generate `
Custom text: Hello World
`. [!code-html[Main](razor/sample/Views/Home/Contact10.cshtml)] You can't use `@model` and `@inherits` on the same page. You can have `@inherits` in a *_ViewImports.cshtml* file that the Razor page imports. For example, if your Razor view imported the following *_ViewImports.cshtml* file: [!code-html[Main](razor/sample/Views/_ViewImportsModel.cshtml)] The following strongly typed Razor page [!code-html[Main](razor/sample/Views/Home/Login1.cshtml)] Generates this HTML markup: ```none
The Login Email: Rick@contoso.com
Custom text: Hello World
``` When passed "[Rick@contoso.com](mailto:Rick@contoso.com)" in the model: See [Layout](layout.md) for more information. ### `@inject` The `@inject` directive enables you to inject a service from your [service container](../../fundamentals/dependency-injection.md) into your Razor page for use. See [Dependency injection into views](dependency-injection.md). ### `@functions` The `@functions` directive enables you to add function level content to your Razor page. The syntax is: ```none @functions { // C# Code } ``` For example: [!code-html[Main](razor/sample/Views/Home/Contact6.cshtml)] Generates the following HTML markup: ```none
From method: Hello
``` The generated Razor C# looks like: [!code-csharp[Main](razor/sample/Classes/Views_Home_Test_cshtml.cs?range=1-19)] ### `@section` The `@section` directive is used in conjunction with the [layout page](layout.md) to enable views to render content in different parts of the rendered HTML page. See [Sections](layout.md#layout-sections-label) for more information. ## TagHelpers The following [Tag Helpers](tag-helpers/index.md) directives are detailed in the links provided. * [@addTagHelper](tag-helpers/intro.md#add-helper-label) * [@removeTagHelper](tag-helpers/intro.md#remove-razor-directives-label) * [@tagHelperPrefix](tag-helpers/intro.md#prefix-razor-directives-label) ## Razor reserved keywords ### Razor keywords * functions * inherits * model * section * helper (Not supported by ASP.NET Core.) Razor keywords can be escaped with `@(Razor Keyword)`, for example `@(functions)`. See the complete sample below. ### C# Razor keywords * case * do * default * for * foreach * if * lock * switch * try * using * while C# Razor keywords need to be double escaped with `@(@C# Razor Keyword)`, for example `@(@case)`. The first `@` escapes the Razor parser, the second `@` escapes the C# parser. See the complete sample below. ### Reserved keywords not used by Razor * namespace * class ## Viewing the Razor C# class generated for a view Add the following class to your ASP.NET Core MVC project: [!code-csharp[Main](razor/sample/Services/CustomCompilationService.cs)] Override the `ICompilationService` added by MVC with the above class; [!code-csharp[Main](razor/sample/Startup.cs?highlight=4&range=29-33)] Set a break point on the `Compile` method of `CustomCompilationService` and view `compilationContent`. ![Text Visualizer view of compilationContent](razor/_static/tvr.png)