data:image/s3,"s3://crabby-images/0ebe3/0ebe35938eba90bfd83594ee7c5ac13c656dc9a8" alt="clock"
April 8, 2013 09:08 by
Scott
This quick article is a response to a question I received today on Facebook. Please use the following procedure to add metatags on .cshtml pages.
Step 1
When we create a MVC4 Application using an Internet Template we get a "Shared" folder inside the "Views" folder on the root and in the "Shared" folder you will find a layout page named "_Layout.cshtml". Open that file.
Step 2
In the "_Layout.cshtml" page add a new section call inside the <head> tag, as given below:
data:image/s3,"s3://crabby-images/58ebb/58ebbb4f4669b6080a11face4378680c059e49d8" alt="image_1"
In the above image you can see that a section call is not required; in other words whenever we need metatags on a page we can define.
Step 3
Now, open you .cshtml page where you wish to add metatags and add the following section reference:
data:image/s3,"s3://crabby-images/a38ad/a38adebf21e8e68cad480c0e9be6eac87257debb" alt="image_2"
Step 4
Now, open the page in a browser and you will see your metatags in action.
data:image/s3,"s3://crabby-images/30f62/30f62ede9bd79552825d2d7dd350d056c0763817" alt="image_3"
Advanced
We can also make these metatags dynamic, in other words we can control them from controllers.
Controller
public ActionResult Index()
{
ViewBag.Message = "Modify this template to jump-start your ASP.NET MVC application.";
ViewBag.MetaKeywords = "abc";
ViewBag.MetaDescription = "abc";
return View();
}
Section on .cshtml page
@section metatags {
<meta name='keywords' content='@ViewBag.MetaKeywords'/>
<meta name='description' content='@ViewBag.MetaDescription'/>
}
Hope this helps.