web mvc,MVC @RenderBody、@RenderSection、@RenderPage、@Html.RenderPartial、@Html.Ren

 2023-10-09 阅读 25 评论 0

摘要:1、@RenderBody() 作用和母版頁中的服務器控件類似,當創建基于此布局頁面的視圖時,視圖的內容會和布局頁面合并,而新創建視圖的內容會通過布局頁面的@RenderBody()方法呈現在標簽之間。這個方法不需要參數,而且只能出現一次。 ? 2、@

1、@RenderBody()

作用和母版頁中的服務器控件類似,當創建基于此布局頁面的視圖時,視圖的內容會和布局頁面合并,而新創建視圖的內容會通過布局頁面的@RenderBody()方法呈現在標簽之間。
這個方法不需要參數,而且只能出現一次。

?

2、@RenderPage


從名稱可以猜出來這個方法是要呈現一個頁面。比如網頁中固定的頭部可以單獨放在一個共享的視圖文件中,然后在布局頁面中通過這個方法調用,用法如下:
@RenderPage(“~/Views/Shared/_Header.cshtml”)?
帶參數
@RenderPage(“~/Views/Shared/_Header.cshtml”,new{parm="my",parm2="you")?
調用頁面獲取參數:
//獲取 RenderPage() 傳遞過來的參數
@PageData["param"]

?

3、 @RenderSection

web mvc。
布局頁面還有節(Section)的概念,也就是說,如果某個視圖模板中定義了一個節,那么可以把它單獨呈現出來,用法如下:
@RenderPage(“~/Views/Shared/_Header.cshtml”)?
@RenderBody()?//模板里添加了一個節
@RenderSection(“head”)
當然還要在視圖中定義節,否則會出現異常:
@section head{?
//do
}
為了防止因缺少節而出現異常,可以給RenderSection()提供第2個參數:
@RenderSection("SubMenu", false)

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

4、@Html.Partial


 Partial 每次都會創建自己的 TextWriter 實例并且把內容緩存在內存中. 最后把所有 writer輸出的內容發送到一個 MvcString對象中
更多時候我們會使用 @{ Html.RenderPartial("Details"); } 而不是@Html.Partial

RenderPage()和RenderPartial()的區別

RenderPage()調用的頁面只能使用其傳遞過去的數據。
而RenderPartial()是可以使用viewdata,model等數據的。

Html.RenderPartial和Html.RenderAction的區別

mvc controller,Html.RenderPartial適合用在重覆使用的UserControl,并且只需要透過Model來呈現內容,或是對于廣告的UserControl也適合使用。 Html.RenderAction則會先去呼叫Controller的Action方法,如果此UserControl是需要透過資料庫取得資料來呈現(透過Action來讀取資料庫),此時會比較適合使用此方式。

5、@Html.Partial("MyView") VS ?@Html.RenderPartial 區別

共同點:兩者都可以輸出一個Partial視圖

區別:

5.1、 Partial有返回值(MvcHtmlString);RenderPartial沒有返回值(Void)。

5.2、兩種寫法不一樣需注意

render_template。5.3、Partial是將視圖內容直接生成一個字符串并返回,RenderPartial方法是直接輸出至當前HttpContext。因此它們在視圖中的使用方式是不同的,

 @{ Html.RenderPartial("_NavMenu");            }@Html.Partial("_NavMenu");
 
?

轉載于:https://www.cnblogs.com/PEPE/p/3698820.html

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/1/134205.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息