天天看點

ASP.NET MVC載入頁面常用方法

@RenderBody

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

@RenderBody()
      

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

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

@RenderPage

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

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

帶參數:

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

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

@PageData["param"]
      

@RenderSection

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

@RenderSection("Header")
      

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

@section head{
     //do
}
      

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

@RenderSection("SubMenu", false)
      

或:

@if (IsSectionDefined("SubMenu"))
    {
        @RenderSection("SubMenu", false)
    }
    else
    {
        <p>SubMenu Section is not defined!</p>
    }
      

@Html.Partial

Partial 每次都會建立自己的 TextWriter 執行個體并且把内容緩存在記憶體中. 最後把所有 Writer 輸出的内容發送到一個 MvcString 對象中,更多時候我們會使用:

@{
        Html.RenderPartial("Details");
    }
      

而不是:

@Html.Partial("Details")
      

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

@RenderPage()調用的頁面隻能使用其傳遞過去的資料。

@RenderPartial()是可以使用viewdata,model等資料的。

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

@Html.RenderPartial适合用在重覆使用的UserControl,并且隻需要透過Model來呈現内容,或是對于廣告的UserControl也适合使用。

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

如果您覺得本文對你有用,不妨幫忙點個贊,或者在評論裡給我一句贊美,小小成就都是今後繼續為大家編寫優質文章的動力,百小僧拜謝!

歡迎您持續關注我的部落格:)

作者:百小僧

版權所有,歡迎保留原文連結進行轉載:)

繼續閱讀