详解ASP.NETMVC3新的Layout布局系统

I:回忆MVC2当中MasterPage那些事

创新互联公司为客户提供专业的网站制作、做网站、程序、域名、空间一条龙服务,提供基于WEB的系统开发. 服务项目涵盖了网页设计、网站程序开发、WEB系统开发、微信二次开发、移动网站建设等网站方面业务。

大家先看下面的代码:

 
 
 
 
  1.  
  2.  
  3. <%@ Master Language="C#"   
  4.     Inherits="System.Web.Mvc.ViewMasterPage" %> 
  5. Master head  
  6.  
  7. Master1...  
  8.  
  9. Master2...  
  10.  
  11. Master3...  
  12.  
  13.  
  14.  
  15.  
  16.  
  17. <%@ Page Language="C#"   
  18.     MasterPageFile="~/Views/Shared/Site.Master"   
  19.     Inherits="System.Web.Mvc.ViewPage" %> 
  20.  
  21. MainContent...  
  22.  
  23.  
  24.  
  25. OtherContent...  
  26.  
  27.  
  28.  
  29. AnyContent...  
  30.  
  31.  
  32.  
  33.  
  34. Master head  
  35. MainContent...  
  36. Master1...  
  37. OtherContent...  
  38. Master2...  
  39. AnyContent...  
  40. Master3...  
  41.  

我们可以看到在Master中ContentPlaceHolder服务端控件起到了一个占位符的作用.***输出的,其实是在View当中的Content服务端控件内的内容,接下来开始介绍Layout.

II:ASP.NET MVC3 新的Layout布局系统

在MVC3当中我们可以利用新的Layout布局系统来代替掉原来在MVC2当中使用的MasterPage(当然在MVC3当中,如果你是继续使用ASPX视图引擎的话,那么还是可以用回原来的MasterPage,然后~~~~然后~你会和runat=”server”保持着从.NET 1.x到.NET 4.0以来从没有间断过的合作关系,可谓缘分呀!).

我们在VS2010 MVC3项目中创建Item时,从创建向导中可以看到以下新增的几个Item

下面进行逐一介绍:

Layout页:

该家伙其实就相当于原来的Master文件.为站点的统一主题界面和减少大部分冗余的Html,head,body标记曾作出过很大的贡献.可谓是功不可莫啊!MasterPage他的诞生是在.NET 2.0版本!在服役到.NET4.0版本后出现了一个新成员[Layout]去向他挑战.MasterPage能否经得起新成员的挑战呢?这个还是得留各位观众做详细对比吧!

Partial页:

相当于原来的UserControl.它可以为你减轻不少需要重复劳动的时间!

View页:

就是View啦.创建它时.一般都是在不需要使用Layout/MasterPage的时候.

View Page with Layout:

等同于原来的View Content Page.它的功能只是为了实现原来在Layout/MasterPage下所定义的占位符.当然在原来的MasterPage中如果你没有实现原先定义的占位符,那么在最终合并输出的时候MasterPage占位符那里就会输出空.

以上这4个新成员都是可以利用新的Razor视图引擎进行工作.如果你还没了解Razor那么可以参考我的另外一编文章

1.Layout页基础:

如果你有使用MasterPage的经验,你将会记得如下的几个东西

A:<%@ Master %>

B:<%@ Page %>

C:

D:

但是在Layout中,以上的这些东西将会消失.(作者不排除有WebPages和WebForms兼容工作的可能性)

取而代之的新功能是:

A.Layout属性:等同于原来的MasterPageFile属性.

B.@RenderBody()方法:直接渲染整个View到占位符处,而不需要原来所使用的.

C.@RenderPage()方法:渲染指定的页面到占位符处.

D.@RenderSection方法:声明一个占位符,和原来的功能类似.

E.@section标记:对@RenderSection方法声明的占位符进行实现,和原来的功能类似.

1.1.@RenderBody()方法的使用

首先在~/Views/Shared/下创建一个名为_MyLayout.cshtml的LayoutPage文件,并将默认的内容替换为如下:

 
 
 
 
  1.  
  2.  
  3.  
  4.     @ViewBag.Title 
  5.  
  6.  
  7.     
     
  8.         开始渲染Body 
  9.         @RenderBody()  
  10.         渲染Body结束 
  11.     
 
  •  
  •  
  • 然后打开在~/Views/Home/Index.cshtml文件并替换为如下的内容:

     
     
     
     
    1. @{  
    2.     ViewBag.Title = "首页";  
    3. }  
    4.  
    5.  
    6.     这里就是渲染Body啦.~~不需要写神马<asp:Content />,其实因为RenderBody()不在有歧义.  
     

    ***输出截图为:

    这个与之前MasterPage的代码量相比之下减少了许多,而更为简洁明了.

    ***别忘记把~/Views/_ViewStart.cshtml中的Layout属性改为:

    Layout = "~/Views/Shared/_MyLayout.cshtml";喔.

    在此,你或许会有疑问了.在_Layout中定义的RenderBody()是Render那个页啊?

    答:其实***Render页的归属就是Render你所访问的那个页,比如你访问/Home/Index.那么Render就是Home控制器下的Index.cshtml这个文件, 如果访问的是/Ohter/SomePage时,那么Render的是Ohter控制器下的SomePage这个.cshtml!

    在这里可能有的朋友没有接触过MVC.在此补个基础,在默认的路由设置选项下:

     
     
     
     
    1. public static void RegisterRoutes(RouteCollection routes)  
    2. {  
    3.     routes.IgnoreRoute("{resource}.axd/{*pathInfo}");  
    4.  
    5.     routes.MapRoute(  
    6.         "Default", // Route name  
    7.         "{controller}/{action}/{id}", // URL with parameters  
    8.         new { controller = "Home", action = "Index", id = UrlParameter.Optional } 
    9. // Parameter defaults  
    10.     );  
    11.  

    请求地址:http://localhost/Home/Index的工作流程为下图(这里没有考虑Layout):

    如果这个RenderBody满足不了你的业务需求,请放心,在此介绍另外一个Render方式RenderPage().它可以让你指定要Render的页.

    1.2.@RenderPage()方法的使用

    在~/Views/Home/文件夹下新建立一个ViewPage1.cshtml文件,将内容改为如下:

     
     
     
     
    1.  
    2.     这里是~/Views/Home/ViewPage1.cshtml,老规矩:还是不用写<asp:Content /> 
     

    并在原来的_MyLayout.cshtml文件中增加几行代码变成下面的这个样子:

     
     
     
     
    1.  
    2.  
    3.  
    4.  
    5.     @ViewBag.Title 
    6.  
    7.  
    8.     
       
    9.         开始渲染Body 
    10.         @RenderBody()  
    11.         渲染Body结束 
    12.          
    13.         开始渲染其他页 
    14.         @RenderPage("~/Views/Home/ViewPage1.cshtml")  
    15.         渲染其他页结束 
    16.           
    17.      
    18.  
    19.  

    我们来看最终的输出效果:

    在这里记住:@RenderBody()只能在_Layout.cshtml中使用一次,而@RenderPage()则可以使用多次!

    好了在这里如果还有不明白的朋友们.我下面上个图说明Render的工作原理

    如果想要了解在Layout中如何使用类似于原来MasterPage中的功能请继续往下看.

    III:在Layout布局系统中实现类似于原来MasterPage功能的实现方式

    好,写到这里开始介绍上一章节中没有介绍完的两个东西:@RenderSection方法和@section标记

    1.@RenderSection()方法等价于,用途为在Layout中声明一个占位符.

    操作:在原来的_MyLayout.cshtml文件中更改内容为如下:

     
     
     
     
    1. @{  
    2.     //some code  
    3. }  
    4.  
    5.  
    6.  
    7.  
    8.     @ViewBag.Title 
    9.  
    10.  
    11.     
       
    12.         开始渲染Body 
    13.         @RenderBody()  
    14.         渲染Body结束 
    15.          
    16.         开始渲染其他页 
    17.         @RenderPage("~/Views/Home/ViewPage1.cshtml")  
    18.         渲染其他页结束 
    19.          
    20.         HOHO,开始学习Section了 
    21.         开始渲染Section 
    22.         声明方式1(推荐):SectionA: 
    23.         @RenderSection("SectionA", false)  
    24.         ------- 
    25.           
    26.         声明方式2:SectionB: 
    27.         @{  
    28.             if (IsSectionDefined("SectionB"))  
    29.             {  
    30.                 @RenderSection("SectionB")  
    31.             }  
    32.         }  
    33.         ------- 
    34.         渲染Sction结束 
    35.      
    36.  
    37.  

    在~/Views/Home/Index.cshtml中更改为如下内容:

     
     
     
     
    1. @{  
    2.     ViewBag.Title = "首页";     
    3.     //  
    4.     // some code  
    5.     //  
    6. }  
    7. @section SectionA{  
    8.     
      这里是SectionA:也不需要写神马runat="server"啊,有木有
       
    9. }  
    10. @section SectionB{  
    11.     
      这里是SectionB:也不需要写神马<asp:Content />啊,有木有
       
    12. }  
    13.  
    14.     这里就是渲染Body啦.~~不需要写神马<asp:Content />,其实因为RenderBody()不在有歧义.  
    15.  

    ***显示的页面效果:

    问:为什么为什么要推荐方式1呢?
    答:因为RenderSection()方法有2个重载.

    如果使用***个只接受一个string类型参数的重载的话.~如果你在具体的View中没有利用@section来定义实现的话,运行会报错.所以需要配合另外一个方法IsSectionDefined()来使用,才能防止报错.

    而使用第2个重载就可以利用第二个bool类型的参数指明该Section是否为必须的.所以可以在使用该RenderSection方法的时候直接利用第二个重载,再把bool参数值设为false,即使你在具体的View中没有声明实现@section,运行起来也一如既往地蛋定,不Show黄页.

    IV:关于前篇文章中有热心的观众朋友们问到如何在Layout(MasterPage)中读取数据库并初始化页面的问题的解答

    在这里只是做个一简单的示范,新建一个类文件,替换如下:

     
     
     
     
    1. using System;  
    2. using System.Collections.Generic;  
    3. using System.Linq;  
    4. using System.Web;  
    5. using System.Data;  
    6. using System.Data.SqlClient; //在这里就用ADO.NET方式吧.EF我接触不久!  
    7.  
    8. namespace Mvc3Application1  
    9. {  
    10.     public class ReaderSQL_Date  
    11.     {  
    12.         private static readonly string _SQL_CONN_STR = "server=.\\mssqlserver,1433;uid=sa;pwd=yourpwd;database=student;";  
    13.  
    14.         public static IList GetAllStudent()  
    15.         {  
    16.             //这里仅仅是做演示,生产环境并不这样写  
    17.             using (SqlConnection conn = new SqlConnection(_SQL_CONN_STR))  
    18.             {  
    19.                 SqlCommand cmd = conn.CreateCommand();  
    20.                 cmd.CommandType = CommandType.Text;  
    21.                 cmd.CommandText = "SELECT [Sno],[Sname],[Sage] FROM [dbo].[STUDENT]";  
    22.  
    23.                 IList result = new List();  
    24.                 conn.Open();  
    25.                 using (SqlDataReader sdr = cmd.ExecuteReader())  
    26.                 {  
    27.                     while (sdr.Read())  
    28.                     {  
    29.                         result.Add(new StudentEntity  
    30.                         {  
    31.                             S_No = sdr.GetInt32(0),  
    32.                             S_Name = sdr.GetString(1),  
    33.                             S_Age = sdr.GetInt32(2)  
    34.                         });  
    35.                     }  
    36.                 }  
    37.                 //SqlConnection.ClearPool(conn); //可选清理连接池.  
    38.  
    39.                 return result;  
    40.             }  
    41.         }  
    42.     }  
    43.  
    44.     public class StudentEntity  
    45.     {  
    46.         public int S_No { get; set; }  
    47.         public string S_Name { get; set; }  
    48.         public int S_Age { get; set; }  
    49.     }  

    _MyLayout.cshtml替换如下:

     
     
     
     
    1. @{  
    2.     IList studentEntities = Mvc3Application1.ReaderSQL_Date.GetAllStudent();  
    3. }  
    4.  
    5.  
    6.  
    7.  
    8.     @ViewBag.Title 
    9.  
    10.  
    11.     
       
    12.  
    13.         @{  
    14.              
    15.                 
    16.  
    17.                     
    18.  
    19.                     
    20.  
    21.                     
    22.  
    23.                 
    24.  
    25.                 @foreach (Mvc3Application1.StudentEntity item in studentEntities)  
    26.                 {  
    27.                     
    28.  
    29.                         
    30.  
    31.                         
    32.  
    33.                         
    34.  
    35.                     
    36.  
    37.                 }  
    38.             
    39. 学号 姓名 年龄
      @item.S_No @item.S_Name @item.S_Age
       
    40.         }  
    41.  
    42.         开始渲染Body 
    43.         @RenderBody()  
    44.         渲染Body结束 
    45.          
    46.         开始渲染其他页 
    47.         @RenderPage("~/Views/Home/ViewPage1.cshtml")  
    48.         渲染其他页结束 
    49.          
    50.         HOHO,开始学习Section了 
    51.         开始渲染Section 
    52.         声明方式1(推荐):SectionA: 
    53.         @RenderSection("SectionA", false)  
    54.         ------- 
    55.           
    56.         声明方式2:SectionB: 
    57.         @{  
    58.             if (IsSectionDefined("SectionB"))  
    59.             {  
    60.                 @RenderSection("SectionB")  
    61.             }  
    62.         }  
    63.         ------- 
    64.         渲染Sction结束 
    65.      
    66.  
    67.  

    最终显示:

    原文链接:http://www.cnblogs.com/highend/archive/2011/04/18/asp_net_mvc3_layout.html

    【编辑推荐】

    1. 浅谈ASP.NET MVC 3中如何使用Model
    2. 体验ASP.NET MVC 3中的Razor特性
    3. MVC架构模式为什么这样“红”?
    4. 专访微软MVP衣明志:走进ASP.NET MVC 2框架开发
    5. ASP.NET MVC 3基础教程之Web Pages

    标题名称:详解ASP.NETMVC3新的Layout布局系统
    文章位置:http://www.csdahua.cn/qtweb/news41/58991.html

    网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网

    成都快上网为您推荐相关内容

    网站改版知识

    分类信息网