MVC 3 renderbody()


ASP.NET MVC 3 已經正式發布了,現在估計許多人都在拼命學,我也不能例外,剛剛看到了一篇文章,介紹了三個非常有用的方法:RenderBody,RenderPage和RenderSection,現在自己再總結下。

1. RenderBody

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

@RenderBody()

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

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

2. RenderPage

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

@RenderPage(“~/Views/Shared/_Header.cshtml”) 
@RenderBody()

代碼簡潔直觀,另外似乎帶下划線的視圖文件有特殊含義,以后再研究吧。

3. RenderSection

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

@RenderPage(“~/Views/Shared/_Header.cshtml”) 
@RenderBody() 
@RenderSection(“footer”)

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

@section footer { 
    Footer Here 
}

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

@RenderSection(“footer”, false)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM