Creating the website layout

This page is a part of a tutorial, which you should follow sequentially, from the beginning to the end. Go to the first page: Getting started with Kentico.

You will learn about:

Your tutorial website is coming up nicely! In the previous steps, you have created all the resources you’ll need to build your MVC application. 

To achieve a consistent experience on your website, create a layout view. The view will contain the website’s header, navigation menu, and footer content, and ensure a uniform look across all pages on the website. You will also add a _ViewStart file that assigns the default layout to all views in your MVC project.

You will also take your next steps towards enabling page builder functionality on the site.

Adding CSS resources

The basic design of the Medio clinic website relies on CSS styles from the styles.css file in the tutorial resources (you can download the resources here: TutorialWebsite.zip. We recommend that you keep design-related resources apart from the rest of the code in the MVC application.

Add the CSS resources by following these steps:

  1. In Visual Studio, include the necessary styles by adding the styles.css file from the tutorial resources to the Content folder in the MEDIOClinic project.

  2. Open the App_Start/BundleConfig.cs file and edit the RegisterBundles method.

    • The project template your MVC application is based on contains two bundles used for bundling CSS and JavaScript files. In this tutorial, you will only be working with the CSS bundle. You can safely ignore the JavaScript bundle.
  3. Add the styles.css file to the “~/Content/css” bundle. The RegisterBundles method should now look like the following:

    
    
    
     public static void RegisterBundles(BundleCollection bundles)
     {
         // Custom JavaScript files from the ~/Scripts/ directory can be included as well
         bundles.Add(new ScriptBundle("~/bundles/scripts").Include(
                     "~/Scripts/site.js"));
    
         // Custom CSS files from the ~/Content/ directory can be included as well
         bundles.Add(new StyleBundle("~/Content/css").Include(
                     "~/Content/site.css",
                     "~/Content/styles.css"));
     }
    
    
     

    Use style and script bundling to reduce the overall size of the site’s style and script files and minimize the number of requests made to the server when loading each page. Learn more abound bundling on Microsoft’s official documentation portal: Bundling and minification.

Your project now contains the stylesheet you will use to define the website’s design.

Creating the site layout

In this step, you will create the layout view.

  1. In Visual Studio, open Views/Shared/_Layout.cshtml.

  2. Replace the code in _Layout.cshtml with the sample code in the index.html file from the tutorial resources (you can download the resources here: TutorialWebsite.zip).

  3. Locate the <title>…</title> tags, and replace the hardcoded page title Tutorial website with a Medio Clinic - prefix and the Razor call @ViewBag.Title.

  4. Render the style bundle containing the site’s styles.css file inside the <head> tags.

    
    
    
     @Styles.Render("~/Content/css")
    
    
     
  5. Add a styles Razor section before the closing </head> tag. The section will be used to add page-specific stylesheets for views that use the page builder.

    
    
    
     @RenderSection("styles", required: false)
    
    
     
  6. Delete the content between the closing </header> andopening <footer> tags, and replace it with the Razor call @RenderBody().

  7. Add a scripts Razor section before the closing </body> tag. The section will be used to add page-specific scripts for views that use the page builder.

    
    
    
     @RenderSection("scripts", required: false)
    
    
     
  8. Your _Layout.cshtml code should look like this:

    
    
    
     <!DOCTYPE html>
     <html lang="en">
     <head>
         <meta charset="utf-8">
         @* Dynamically resolves the page's title *@
         <title>Medio Clinic - @ViewBag.Title</title>
         <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7" crossorigin="anonymous">
         <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.6.3/css/font-awesome.min.css">
         <link href="http://fonts.googleapis.com/css?family=Lato:400,700italic&amp;subset=latin,latin-ext" rel="stylesheet" type="text/css">
         <link href="http://fonts.googleapis.com/css?family=Lobster" rel="stylesheet" type="text/css">
    
         @* Loads the styles.css resource *@
         @Styles.Render("~/Content/css")
         @* Razor section for additional page-specific styles *@
         @RenderSection("styles", required: false)
     </head>
    
     <body>
         <header>
             <div class="col-sm-offset-3 col-sm-6">
                 <div class="col-sm-6">
                     <a href="./index.html" title="MedioClinic homepage" class="logo">MEDIO clinic</a>
                 </div>
                 <div class="col-sm-6 nav">
                     <nav>
                         <a href="./index.html" title="Home">Home</a>
                         <a href="./medical-center.html" title="Medical centers">Medical center</a>
                     </nav>
                 </div>
             </div>
             <div class="clearfix"></div>
         </header>
    
         @* Loads the content of your Tutorial's pages as sub views *@
         @RenderBody()
    
         <footer>
             <div class="col-sm-offset-3 col-sm-6">
                 <div class="row">
                     <div class="col-sm-6">
                         <h4>MEDIO clinic</h4>
                         <ul>
                             <li><i class="fa fa-map-marker"></i> Address: <address>7A Kentico street, Bedford, NH 03110, USA</address></li>
                             <li><i class="fa fa-envelope-o"></i> E-mail: <a href="mailto:info@medio-clinic.com" title="Email us">info@medio-clinic.com</a></li>
                             <li><i class="fa fa-phone"></i> Phone number: <a href="tel:5417543010" title="Phone us">(541) 754-3010</a>
                         </ul>
                     </div>
                     <div class="col-sm-6">
                         <span class="cms">Powered by <a href="http://www.kentico.com" title="Kentico CMS">Kentico CMS for ASP.NET</a></span>
                     </div>
                 </div>
             </div>
             <div class="clearfix"></div>
         </footer>
    
         @* Razor section for additional page-specific scripts *@
         @RenderSection("scripts", required: false)
     </body>
     </html>
    
    
     
  9. Save your changes

You now have a consistent layout for your website. You also have the option to change the common layout for all views in a single location, if you want to provide your site’s visitors with a different experience.

Previous page: Working with generated classes in the MVC application — Next page: Displaying the page content

Completed pages: 7 of 10