1. 程式人生 > >MVC頁面常用方法

MVC頁面常用方法

on() erb 母版 概念 參數 com 資料庫 每次 母版頁

轉自:https://www.cnblogs.com/baisoft/p/5839319.html

@RenderBody

在Razor引擎中沒有了“母版頁”,取而代之的是叫做“布局”的頁面(_Layout.cshtml)放在了共享視圖文件夾中。在這個頁面中,會看到標簽裏有這樣一條語句:

1 @RenderBody()

其實它的作用和母版頁中的服務器控件類似,當創建基於此布局頁面的視圖時,視圖的內容會和布局頁面合並,而新創建視圖的內容會通過布局頁面的@RenderBody()方法呈現在標簽之間。

這個方法不需要參數,而且只能出現一次。

@RenderPage

從名稱可以猜出來這個方法是要呈現一個頁面。比如網頁中固定的頭部可以單獨放在一個共享的視圖文件中,然後在布局頁面中通過這個方法調用,用法如下:

1 @RenderPage("~/Views/Shared/_Header.cshtml")

帶參數:

1 @RenderPage("~/Views/Shared/_Header.cshtml", new { parm = "my", parm2 = "you" })

被@RenderPage的頁面獲取傳遞過來的參數:

1 @PageData["param"]

@RenderSection

布局頁面還有節(Section)的概念,也就是說,如果某個視圖模板中定義了一個節,那麽可以把它單獨呈現出來,用法如下:

1 @RenderSection("Header")

當然還要在視圖中定義節,否則會出現異常:

1 2 3 @section head{ //do }

為了防止因缺少節而出現異常,可以給RenderSection()提供第2個參數:

1 @RenderSection("SubMenu", false)

或:

1 2 3 4 5 6 7 8 @if (IsSectionDefined("SubMenu")) { @RenderSection(
"SubMenu", false) } else { <p>SubMenu Section is not defined!</p> }

@Html.Partial

Partial 每次都會創建自己的 TextWriter 實例並且把內容緩存在內存中. 最後把所有 Writer 輸出的內容發送到一個 MvcString 對象中,更多時候我們會使用:

1 2 3 @{ Html.RenderPartial("Details"); }

而不是:

1 @Html.Partial("Details")

@RenderPage()和@RenderPartial()的區別

@RenderPage()調用的頁面只能使用其傳遞過去的數據。

@RenderPartial()是可以使用viewdata,model等數據的。

@Html.RenderPartial和@Html.RenderAction的區別

@Html.RenderPartial適合用在重覆使用的UserControl,並且只需要透過Model來呈現內容,或是對於廣告的UserControl也適合使用。

@Html.RenderAction則會先去呼叫Controller的Action方法,如果此UserControl是需要透過資料庫取得資料來呈現(透過Action來讀取資料庫),此時會比較適合使用此方式。

MVC頁面常用方法