Partial View指可以應用於View中以作為其中一部分的View的片段(類似於之前的user control), 可以像類一樣,編寫一次, 然后在其他View中被反復使用。
一般放在"Views/Shared"文件夾中以共享。
創建Partial View:一般直接右鍵"Views/Shared"文件夾添加分部視圖。
使用Partial View有兩類helper :
Html.Partial / Html.RenderPartial
Html.Action / Html.RenderAction
創建分部視圖
如下圖,創建 _PartialPageWidget.cshtml


我們做一個簡陋的widget.
參考下面的圖,定義widget的HTML結構。

借用了bootstrap中panel的樣式,結構如下。

通過Html.Partial / Html.RenderPartial 使用
直接應用Html.Partial或Html.RenderPartial輔助方法比較簡單。
打開之前建好的Views/MVCDemo/Index.cshtml文件,添加如下內容:

顯示結果:

通過Html.Action / Html.RenderAction 使用
通過Html.Action/Html.RenderAction使用稍微復雜一點,分成兩步。
-
在要顯示的View所對應的Controller中心增加一個Action.
還用上面這個頁面,我們在MVCDemoController.cs中增加一個Action

做個簡單的說明:
-
[ChildActionOnly] 表示這個Action只應作為子操作進行調用。也就是說直接通過 controller/action這樣的網址是不能訪問的,會提示只能由子請求訪問的錯誤。
-
必須返回一個PartialView
-
-
在View中添加相關代碼

顯示結果和上一種方法一樣

兩種使用方式小結
當View中引用了一個或多個分部視圖時,此View與各分部視圖默認得到一樣的數據,也就是說View及其中所有的Partial View默認情況下共享View中的ViewData和ViewBag.
需要使View和其中引入的Partial View有不同的數據,需要通過Html.Action/Html.RenderAction輔助方法, 並在對於被調用的Action中設置對應的數據。
另外還有幾點需要注意:
-
XXX和RenderXXX的區別在於,一個是直接返回字符串,另外一個是直接寫入到相應輸出流,因此不能直接放在代碼表達式中,必須放在代碼塊中。
前面的示例中兩種寫法是等價的。RenderXXX有輕微的性能優勢,在大量的RenderXXX運行時,才能反映出性能上的優勢。
-
Partial/RenderPartial通常在單獨的文件夾中應用視圖標記來幫助View渲染視圖模型的一部分。
Action/RenderAction執行單獨Controller中的Action來顯示結果,提供了更多的靈活性,例如利用單獨的Controller傳遞不同值。文章最后我們會舉個例子說明。
-
Partial/RenderPartial和Action/RenderAction的參數分別是 partialView和 Action的名字。當然還有其他的重載函數,我們只說最常用的。應用時可以按照我們前面舉的例子。
Html.Partial和Html.Action差異舉例
最后我們舉個例子說明兩種用法的差別。
-
新建一個Partial View

-
Controller中新建兩個Action,SharedDateDemo和PartialViewDate.
根據SharedDateDemo生成主View, PartialViewDate供Html.Action調用

-
主View: SharedDateDemo.cshtml分別顯示
主View的時間;
用Html.Partial調用Partial View的時間;
用Html.Action調用Partial View的時間。

顯示結果:

上面結果可以清晰的看到:
-
View及其中所有的Partial View默認情況下共享View中的ViewData和ViewBag
-
可以通過Html.Action, 配合被調用的Action改變傳遞不同的數據。
-
Html.Partial使用方便,在不需要改變數據內容時非常方便。
Html.Action 使用更加靈活,可以根據業務要求按需定制Partial View顯示內容。
