Skip to main content

ASP.NET MVC – Razor


ASP.NET MVC – Razor Engine

Razor is a markup syntax that lets you embed server-based code into web pages using C#. It is not a programming language. It is a server side markup language.

Razor is one of the view engine supported in ASP.NET MVC. Razor allows you to write mix of HTML and server side code using C#. Razor view using C# syntax has .cshtml file extension.
Razor syntax has following Characteristics:
  • Compact: Razor syntax is compact which enables you to minimize number of characters and keystrokes required to write a code.
  • Easy to Learn: Razor syntax is easy to learn where you can use your familiar language C#.
  • Intellisense: Razor syntax supports statement completion within Visual Studio.
Razor has no ties to ASP.NET MVC because Razor is a general-purpose templating engine. You can use it anywhere to generate output like HTML. It's just that ASP.NET MVC has implemented a view engine that allows us to use Razor inside of an MVC application to produce HTML.

Razor Vs ASPX

·        Razor is very similar to how ASPX (classic ASP pages) files work. ASPX files are templates, which contain literal text and some C# code that specifies where your data should appear. We execute those to generate the HTML for our application.
·        ASPX files have a dependency on the ASP.NET runtime to be available to parse and execute those ASPX files. Razor has no such dependencies.

Main Razor Syntax Rules for C#

ü Razor code blocks are enclosed in @{ ... }
ü Inline expressions (variables and functions) start with @
ü Code statements end with semicolon
ü Variables are declared with the var keyword
ü Strings are enclosed with quotation marks
ü C# code is case sensitive
ü C# files have the extension .cshtml

Let’s learn to use razor View


Inline expression


We start with @ symbol to write server side C# code with Html code. For example, write @variable_name to display a value of a server side variable. Write @DateTime.Now to display current datetime as shown below. A single line expression does not require a semicolon at the end of the expression.

Razor Syntax (C#)

<h2>RazorTest</h2>
<span>@DateTime.Now.ToString()</span>
<h3>The above code displays current date and time</h3>

Code block with multiple statements


We can write multiple line of server side code enclosed in braces @{ ... }. Each line must ends with semicolon same as we do in C#.

Example of multiple statements to embed server side code into razor
 @{
    ViewBag.Title = "RazorTest";
    var date = DateTime.Now.ToLongDateString();
    var message = "Hello, C# Naija";
}

<h2>RazorTest</h2>
<h3>Today's Date is @date</h3>
<h3>We say @message to our fans</h3>

Model


We use @model to use model object anywhere in the view. But remember to import the model object you want to use with the @model and the object path as shown below

@model DatabaseFirstApproach.Models.employee

@{
    ViewBag.Title = "RazorTest";
    var date = DateTime.Now.ToLongDateString();
    var message = "Employee Details";
}

<h2>RazorTest</h2>
<h3>@message</h3>
<ul>
    <li>Employee Name: @Model.FirrstName</li>
    <li>Employee Phone Number: @Model.PhoneNumber</li>
    <li>Employee Address: @Model.Address</li>
</ul>

Variable Declarations


Declare a variable in a code block enclosed in brackets and then use those variables inside html with @ symbol.

@{
    var str = string.Empty;

    if (100 > 10)
    {
        str = "Hello, C# naija!";
    }
}

<p>@str</p>


Remember the following


Use @ to write server side code.
 Server side code block starts with @{* code * }
 Use @: or <text></<text> to display text from code block.
 if condition starts with @if{ }
 for loop starts with @for
 @model allows you to use model object anywhere in the view.


Comments

Popular posts from this blog

Collections in C#

Collections in C# In our previous article , we have learned about how we can use arrays in C#. Arrays in programming are used to group a set of related objects. So one could create an array or a set of Integers, which could be accessed via one variable name. What is Collections in C#? Collections are similar to Arrays, it provides a more flexible way of working with a group of objects. In arrays, you would have noticed that you need to define the number of elements in an array beforehand. This had to be done when the array was declared. But in a collection, you don't need to define the size of the collection beforehand. You can add elements or even remove elements from the collection at any point of time. This article will focus on how we can work with the different collections available in C#. There are three distinct collection types in C#: standard generic concurrent The standard collections are found under the System.Collections. They do not store elemen...

The String.Join Method in C# Explained

The String.Join Method in C#   The string.Join concatenates the elements of a specified array or the members of a collection, using the specified separator between each element or member. Overloads of string.Join Method Description Join(Char, Object[]) Concatenates the string representations of an array of objects, using the specified separator between each member. Join(Char, String[]) Concatenates an array of strings, using the specified separator between each member. Join(String, IEnumerable<String>) Concatenates the members of a constructed IEnumerable<T> collection of type String, using the specified separator between each member. Join(String, Object[]) Concatenates the elements of an object array, using the specified separator between each element. Join(String, String[]) Concatenates all the elements of a string array, usi...

System.IO Namesapce in C#

  System.IO Namesapce in C# A  file  is a collection of data stored in a disk with a specific name and a directory path. When a file is opened for reading or writing, it becomes a  stream . The stream is basically the sequence of bytes passing through the communication path. There are two main streams: the  input stream  and the  output stream . The  input stream  is used for reading data from file (read operation) and the  output stream  is used for writing into the file (write operation). From the above definition of file, the C# provides a namespace that enable us to manipulate file in C# called System.IO.   System.IO  is a  namespace  and it contains a standard IO (input/output) types such as classes , structures , enumerations , and  delegates  to perform a read/write operations on different sources like file, memory, network, etc.   System.IO Classes The table below shows differen...