開發(fā)的系統(tǒng)越來越復雜,如果程序員不劃分這些區(qū)域,它就會變得很臃腫,接下來錯新技術頻道小編就帶大家來了解ASP.Net MVC 布局頁、模板頁使用方法詳細介紹。
一、Views文件夾 -> Shared文件夾下的 _Layout.cshtml 母版頁
@RenderBody
當創(chuàng)建基于_Layout.cshtml布局頁面的視圖時,視圖的內容會和布局頁面合并,而新創(chuàng)建視圖的內容會通過_Layout.cshtml布局頁面的@RenderBody()方法呈現(xiàn)在標簽之間。
@RenderPage
從名稱可以猜出來這個方法是要呈現(xiàn)一個頁面。比如網頁中固定的頭部可以單獨放在一個共享的視圖文件中,然后在布局頁面中通過這個方法調用,用法如下:
@RenderPage(“~/Views/Shared/_Header.cshtml”)
帶參數(shù)
@RenderPage(“~/Views/Shared/_Header.cshtml”,new{parm="my",parm2="you")
調用頁面獲取參數(shù):
//獲取 RenderPage() 傳遞過來的參數(shù)
@PageData["param"]
@RenderSection
布局頁面還有節(jié)(Section)的概念,也就是說,如果某個視圖模板中定義了一個節(jié),那么可以把它單獨呈現(xiàn)出來
為了防止因缺少節(jié)而出現(xiàn)異常,可以給RenderSection()提供第2個參數(shù):
@RenderSection("head", false)
或
@if (IsSectionDefined("head"))
??????? {
??????????? @RenderSection("head", false)
??????? }
??????? else
??????? {
???????????
SubMenu Section is not defined!
??????? }
?
?代碼如下:
?
@RenderSection("head", required: true)@*View頁面自定義特定js/css使用*@
@RenderPage("~/Views/Shared/_Header.cshtml") @RenderBody()
二、創(chuàng)建視圖,使用母版頁
代碼如下:
@{ ViewBag.Title = "Index"; Layout = "~/Views/Shared/_Layout.cshtml"; } 執(zhí)行C#普通語法
執(zhí)行C#語句段
@{ List三、生成頁面的源代碼
?
執(zhí)行C#普通語法
2013/3/11
執(zhí)行C#語句段
四、@Html.Partial
Partial 每次都會創(chuàng)建自己的 TextWriter 實例并且把內容緩存在內存中. 最后把所有 writer輸出的內容發(fā)送到一個 MvcString對象中
更多時候我們會使用 @{ Html.RenderPartial("Details"); } 而不是@Html.Partial
Html.RenderPartial()與@Html.Partial的區(qū)別
Html.RenderPartial 直接輸出至當前 HttpContext(因為是直接輸出,所以性能好)。
Html.Partial 將視圖內容直接生成一個字符串并返回(相當于有個轉義的過程)。
?
RenderPage()和RenderPartial()的區(qū)別
RenderPage()調用的頁面只能使用其傳遞過去的數(shù)據(jù)。
而RenderPartial()是可以使用viewdata,model等數(shù)據(jù)的。
如:@{Html.RenderPartial("BasicChart",model);}
用這個重載可以在部分視圖里使用強類型,然后在主視圖中使用第二個參數(shù)傳model過去
@{Html.RenderPartial("BasicChart",ViewData["myData"]);}
Html.RenderPartial和Html.RenderAction的區(qū)別
Html.RenderPartial適合用在重覆使用的UserControl,并且只需要透過Model來呈現(xiàn)內容,或是對于廣告的UserControl也適合使用。
Html.RenderAction則會先去呼叫Controller的Action方法,如果此UserControl是需要透過資料庫取得資料來呈現(xiàn)(透過Action來讀取資料庫),此時會比較適合使用此方式。
補充:
1、帶有Render的方法返回值是void,在方法內部進行輸出;不帶的返回值類型為MvcHtmlString,所以只能這樣使用:
@Html.Partial 對應 @{Html.RenderPartial(....);}
@Html.Action 對應 @{Html.RenderAction(....);}
2、Html.Partial可以直接提供用戶控件名作為參數(shù),而Html.Action需要有對應的Action,在Action內部返回PartailResult(即retun PartialView())。
3、對于簡單的沒有任何邏輯的用戶控件,推薦使用Html.Partial;對于需要設置一些Model的用戶控件,推薦使用Html.Action。當然,有Model數(shù)據(jù)也是可以使用Html.Partial方法的,可以看方法的重載。
4、使用Html.Action有個好處,就是可以根據(jù)不同的場景選擇不同的用戶控件。
比如:
@Html.Action("UserInfoControl")
在對應的UserInfoControl這個Action中,在用戶未登錄的時候,可以retun PartialView("LogOnUserControl");登錄后,可以retun PartialView("UserInfoControl");
看完上面介紹的ASP.Net MVC 布局頁、模板頁使用方法詳細介紹,相信大家都了解清楚了,大家可以試試本文的操作。
新聞熱點
疑難解答
圖片精選