成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解ASP.NET MVC 3新的Layout布局系統

開發 后端
今天我們談到的是ASP.NET MVC 3中有關新的Layout布局系統,在MVC3當中我們可以利用新的Layout布局系統來代替掉原來在MVC2當中使用的MasterPage。

I:回憶MVC2當中MasterPage那些事

大家先看下面的代碼:

  1. <!------------Begin--------------> 
  2. <!-- Master文件 --> 
  3. <%@ Master Language="C#"   
  4.     Inherits="System.Web.Mvc.ViewMasterPage" %> 
  5. Master head  
  6. <asp:ContentPlaceHolder ID="MainContent" runat="server" /> 
  7. Master1...  
  8. <asp:ContentPlaceHolder ID="OtherContent" runat="server" /> 
  9. Master2...  
  10. <asp:ContentPlaceHolder ID="AnyContent" runat="server" /> 
  11. Master3...  
  12. <!-------------End---------------> 
  13.  
  14.  
  15. <!------------Begin--------------> 
  16. <!-- 某個View文件 --> 
  17. <%@ Page Language="C#"   
  18.     MasterPageFile="~/Views/Shared/Site.Master"   
  19.     Inherits="System.Web.Mvc.ViewPage" %> 
  20. <asp:Content ID="Content1" ContentPlaceHolderID="MainContent" runat="server"> 
  21. MainContent...  
  22. </asp:Content> 
  23.  
  24. <asp:Content ID="Content2" ContentPlaceHolderID="OtherContent" runat="server"> 
  25. OtherContent...  
  26. </asp:Content> 
  27.  
  28. <asp:Content ID="Content3" ContentPlaceHolderID="AnyContent" runat="server"> 
  29. AnyContent...  
  30. </asp:Content> 
  31. <!-------------End---------------> 
  32. <!------------Begin--------------> 
  33. <!-- ***傳回給客戶端的文件 --> 
  34. Master head  
  35. MainContent...  
  36. Master1...  
  37. OtherContent...  
  38. Master2...  
  39. AnyContent...  
  40. Master3...  
  41. <!-------------End---------------> 

我們可以看到在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

image

下面進行逐一介紹:

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中如果你沒有實現原先定義的占位符<asp:ContentPlaceHolder />,那么在最終合并輸出的時候MasterPage占位符<asp:ContentPlaceHolder />那里就會輸出空.

以上這4個新成員都是可以利用新的Razor視圖引擎進行工作.如果你還沒了解Razor那么可以參考我的另外一編文章

1.Layout頁基礎:

如果你有使用MasterPage的經驗,你將會記得如下的幾個東西

A:<%@ Master %>

B:<%@ Page %>

C:<asp:ContentPlaceHolder />

D:<asp:Content />

但是在Layout中,以上的這些東西將會消失.(作者不排除有WebPages和WebForms兼容工作的可能性)

取而代之的新功能是:

A.Layout屬性:等同于原來的MasterPageFile屬性.

B.@RenderBody()方法:直接渲染整個View到占位符處,而不需要原來所使用的<asp:Content />.

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

D.@RenderSection方法:聲明一個占位符,和原來的<asp:ContentPlaceHolder />功能類似.

E.@section標記:對@RenderSection方法聲明的占位符進行實現,和原來的<asp:Content />功能類似.

1.1.@RenderBody()方法的使用

首先在~/Views/Shared/下創建一個名為_MyLayout.cshtml的LayoutPage文件,并將默認的內容替換為如下:

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4.     <title>@ViewBag.Title</title> 
  5. </head> 
  6. <body> 
  7.     <div> 
  8.         開始渲染Body<br /> 
  9.         @RenderBody()  
  10.         渲染Body結束<br /> 
  11.     </div> 
  12. </body> 
  13. </html> 

然后打開在~/Views/Home/Index.cshtml文件并替換為如下的內容:

  1. @{  
  2.     ViewBag.Title = "首頁";  
  3. }  
  4.  
  5. <div> 
  6.     這里就是渲染Body啦.~~不需要寫神馬&lt;asp:Content /&gt;,其實因為RenderBody()不在有歧義.  
  7. </div> 

***輸出截圖為:
image

這個與之前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):

image

如果這個RenderBody滿足不了你的業務需求,請放心,在此介紹另外一個Render方式RenderPage().它可以讓你指定要Render的頁.

1.2.@RenderPage()方法的使用

在~/Views/Home/文件夾下新建立一個ViewPage1.cshtml文件,將內容改為如下:

  1. <div> 
  2.     這里是~/Views/Home/ViewPage1.cshtml,老規矩:還是不用寫&lt;asp:Content /&gt; 
  3. </div> 

并在原來的_MyLayout.cshtml文件中增加幾行代碼變成下面的這個樣子:

  1. <!DOCTYPE html> 
  2.  
  3. <html> 
  4. <head> 
  5.     <title>@ViewBag.Title</title> 
  6. </head> 
  7. <body> 
  8.     <div> 
  9.         開始渲染Body<br /> 
  10.         @RenderBody()  
  11.         渲染Body結束<br /> 
  12.         <br /> 
  13.         開始渲染其他頁<br /> 
  14.         @RenderPage("~/Views/Home/ViewPage1.cshtml")  
  15.         渲染其他頁結束<br /> 
  16.           
  17.     </div> 
  18. </body> 
  19. </html> 

我們來看最終的輸出效果:

image

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

好了在這里如果還有不明白的朋友們.我下面上個圖說明Render的工作原理

image

如果想要了解在Layout中如何使用類似于原來MasterPage中的<asp:ContentPlaceHolder /><asp:Content />功能請繼續往下看.

III:在Layout布局系統中實現類似于原來MasterPage功能的實現方式

好,寫到這里開始介紹上一章節中沒有介紹完的兩個東西:@RenderSection方法和@section標記

1.@RenderSection()方法等價于<asp:ContentPlaceHolder />,用途為在Layout中聲明一個占位符.

操作:在原來的_MyLayout.cshtml文件中更改內容為如下:

  1. @{  
  2.     //some code  
  3. }  
  4. <!DOCTYPE html> 
  5.  
  6. <html> 
  7. <head> 
  8.     <title>@ViewBag.Title</title> 
  9. </head> 
  10. <body> 
  11.     <div> 
  12.         開始渲染Body<br /> 
  13.         @RenderBody()  
  14.         渲染Body結束<br /> 
  15.         <br /> 
  16.         開始渲染其他頁<br /> 
  17.         @RenderPage("~/Views/Home/ViewPage1.cshtml")  
  18.         渲染其他頁結束<br /> 
  19.         <br /> 
  20.         HOHO,開始學習Section了<br /> 
  21.         開始渲染Section<br /> 
  22.         聲明方式1(推薦):SectionA:<br /> 
  23.         @RenderSection("SectionA", false)  
  24.         -------<br /> 
  25.           
  26.         聲明方式2:SectionB:<br /> 
  27.         @{  
  28.             if (IsSectionDefined("SectionB"))  
  29.             {  
  30.                 @RenderSection("SectionB")  
  31.             }  
  32.         }  
  33.         -------<br /> 
  34.         渲染Sction結束<br /> 
  35.     </div> 
  36. </body> 
  37. </html> 

在~/Views/Home/Index.cshtml中更改為如下內容:

  1. @{  
  2.     ViewBag.Title = "首頁";     
  3.     //  
  4.     // some code  
  5.     //  
  6. }  
  7. @section SectionA{  
  8.     <div>這里是SectionA:也不需要寫神馬runat="server"啊,有木有</div> 
  9. }  
  10. @section SectionB{  
  11.     <div>這里是SectionB:也不需要寫神馬&lt;asp:Content /&gt啊,有木有</div> 
  12. }  
  13. <div> 
  14.     這里就是渲染Body啦.~~不需要寫神馬&lt;asp:Content /&gt;,其實因為RenderBody()不在有歧義.  
  15. </div> 

***顯示的頁面效果:

image


image

問:為什么為什么要推薦方式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<StudentEntity> 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<StudentEntity> result = new List<StudentEntity>();  
  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 { getset; }  
  47.         public string S_Name { getset; }  
  48.         public int S_Age { getset; }  
  49.     }  

_MyLayout.cshtml替換如下:

  1. @{  
  2.     IList<Mvc3Application1.StudentEntity> studentEntities = Mvc3Application1.ReaderSQL_Date.GetAllStudent();  
  3. }  
  4. <!DOCTYPE html> 
  5.  
  6. <html> 
  7. <head> 
  8.     <title>@ViewBag.Title</title> 
  9. </head> 
  10. <body> 
  11.     <div> 
  12.  
  13.         @{  
  14.             <table> 
  15.                 <tr> 
  16.                     <th>學號</th> 
  17.                     <th>姓名</th> 
  18.                     <th>年齡</th> 
  19.                 </tr> 
  20.                 @foreach (Mvc3Application1.StudentEntity item in studentEntities)  
  21.                 {  
  22.                     <tr> 
  23.                         <td>@item.S_No</td> 
  24.                         <td>@item.S_Name</td> 
  25.                         <td>@item.S_Age</td> 
  26.                     </tr> 
  27.                 }  
  28.             </table> 
  29.         }  
  30.  
  31.         開始渲染Body<br /> 
  32.         @RenderBody()  
  33.         渲染Body結束<br /> 
  34.         <br /> 
  35.         開始渲染其他頁<br /> 
  36.         @RenderPage("~/Views/Home/ViewPage1.cshtml")  
  37.         渲染其他頁結束<br /> 
  38.         <br /> 
  39.         HOHO,開始學習Section了<br /> 
  40.         開始渲染Section<br /> 
  41.         聲明方式1(推薦):SectionA:<br /> 
  42.         @RenderSection("SectionA", false)  
  43.         -------<br /> 
  44.           
  45.         聲明方式2:SectionB:<br /> 
  46.         @{  
  47.             if (IsSectionDefined("SectionB"))  
  48.             {  
  49.                 @RenderSection("SectionB")  
  50.             }  
  51.         }  
  52.         -------<br /> 
  53.         渲染Sction結束<br /> 
  54.     </div> 
  55. </body> 
  56. </html> 

最終顯示:

image 

原文鏈接: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
責任編輯:彭凡 來源: 博客園
相關推薦

2010-10-12 09:52:02

ASP.NET MVC

2010-10-08 14:32:32

ASP.NET MVCNuPack

2011-01-15 23:07:59

2011-04-14 09:19:22

ASP.NET MVC

2010-03-19 09:17:16

ASP.NET MVC

2010-09-15 09:18:21

ASP.NET MVC

2009-10-29 09:15:32

ASP.NET MVCDropDownLis

2009-09-10 09:50:47

ASP.NET MVC

2009-09-18 10:20:26

PRG數據驗證

2009-07-31 12:43:59

ASP.NET MVC

2009-07-24 13:20:44

MVC框架ASP.NET

2012-03-31 10:01:40

ASP.NET MVC

2010-08-16 09:14:37

ASP.NET MVC

2010-02-03 09:50:58

ASP.NET MVC

2009-07-24 11:55:29

ASP.NET MVC

2010-10-20 09:05:16

ASP.NET MVC

2010-12-07 09:38:15

ASP.NET MVC

2009-07-20 16:44:56

ASP.NET MVCIValueProvi

2009-07-20 15:44:32

ASP.NET MVC

2009-07-22 09:11:02

Action方法ASP.NET MVC
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费一区 | 日韩中文字幕一区二区 | 国产一区二区精品在线 | 精品久久久精品 | 天天操,夜夜爽 | 久久久妇女国产精品影视 | 免费在线观看黄网站 | 91久久精品一区二区二区 | 中文字幕 在线观看 | 久久99成人 | 成人国产毛片 | 欧美成视频 | 成人在线精品视频 | 欧美伊人 | 欧美精品成人一区二区三区四区 | 欧美日韩成人在线观看 | 春色av| 精品久久久久久18免费网站 | 一区二区三区欧美在线 | 我要看免费一级毛片 | 亚洲成人免费视频在线 | 亚洲国产精品一区二区第一页 | 国产一区二区av | 国产精品99久久久久久动医院 | 麻豆精品国产91久久久久久 | 国产电影一区二区三区爱妃记 | 亚洲网站在线观看 | 韩日一区二区三区 | 国产精品二区三区在线观看 | 欧美91| 日韩在线国产 | 欧美日本韩国一区二区三区 | 日韩成人免费视频 | 久久久美女 | 99re视频在线 | 国产午夜精品理论片a大结局 | 中文字幕一区二区三区四区 | 中文字幕日韩一区 | 久久最新网址 | 久久一区二区三区电影 | 精品国产乱码久久久久久图片 |