AspNetCore.Docs/aspnet/web-pages/overview/mobile/rendering-aspnet-web-pages-...

3.5 KiB

uid title author description ms.author ms.date ms.assetid msc.legacyurl msc.type
web-pages/overview/mobile/rendering-aspnet-web-pages-sites-for-mobile-devices Rendering ASP.NET Web Pages (Razor) Sites for Mobile Devices | Microsoft Docs Rick-Anderson This article describes how to create pages in an ASP.NET Web Pages (Razor) site that will render appropriately on mobile devices. What you'll learn: How to u... riande 02/17/2014 f15ab392-c05e-4269-83bf-7c6d2b8c8ec8 /web-pages/overview/mobile/rendering-aspnet-web-pages-sites-for-mobile-devices authoredcontent

Rendering ASP.NET Web Pages (Razor) Sites for Mobile Devices

by Tom FitzMacken

This article describes how to create pages in an ASP.NET Web Pages (Razor) site that will render appropriately on mobile devices.

What you'll learn:

  • How to use a naming convention to specify that a page is designed specifically for mobile devices.

Software versions used in the tutorial

  • ASP.NET Web Pages (Razor) 3

This tutorial also works with ASP.NET Web Pages 2.

ASP.NET Web Pages lets you create custom displays for rendering content on mobile or other devices.

The simplest way to create device-specific page in an ASP.NET Web Pages site is by using a file-naming pattern like this: FileName.Mobile.cshtml. You can create two versions of a page (for example, one named MyFile.cshtml and one named MyFile.Mobile.cshtml). At run time, when a mobile device requests MyFile.cshtml, ASP.NET renders the content from MyFile.Mobile.cshtml. Otherwise, MyFile.cshtml is rendered.

The following example shows how to enable mobile rendering by adding a content page for mobile devices. Page1.cshtml contains content plus a navigation sidebar. Page1.Mobile.cshtml contains the same content, but omits the sidebar.

  1. In an ASP.NET Web Pages site, create a file named Page1.cshtml and replace the current content with following markup.

    [!code-htmlMain]

  2. Create a file named Page1.Mobile.cshtml and replace the existing content with the following markup. Notice that the mobile version of the page omits the navigation section for better rendering on a smaller screen.

    [!code-htmlMain]

  3. Run a desktop browser and browse to Page1.cshtml. mobilesites-1

  4. Run a mobile browser (or a mobile device emulator) and browse to Page1.cshtml. (Notice that you do not include .mobile. as part of the URL.) Even though the request is to Page1.cshtml, ASP.NET renders Page1.Mobile.cshtml.

    mobilesites-2

[!NOTE] To test mobile pages, you can use a mobile device simulator that runs on a desktop computer. This tool lets you test web pages as they would look on mobile devices (that is, typically with a much smaller display area). One example of a simulator is the User Agent Switcher add-on for Mozilla Firefox, which lets you emulate various mobile browsers from a desktop version of Firefox.

Additional Resources

Windows Phone Emulator