解讀ASP.NET 5 & MVC6系列教程(14):View Component_自學過程

來源:互聯網
上載者:User

在之前的MVC中,我們經常需要類似一種小組件的功能,通常我們都是使用Partial View來實現,因為MVC中沒有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版MVC6中,提供了一種叫做View Component的功能。

你可以將View Component看做是一個mini的Controller——它只負責渲染一小部分內容,而非全部響應,所有Partial View能解決的問題,你都可以使用View Component來解決,比如:動態導覽功能表、Tag標籤、登入視窗、購物車、最近閱讀文章等等。

View Component包含2個部分,一部分是類(繼承於ViewComponent),另外一個是Razor視圖(和普通的View視圖一樣)。就像新版MVC中的Controller一樣,ViewComponent也可以使POCO的(即不繼承ViewComponent類,但類名以ViewComponent結尾)。

View Component的建立

目前,View Component類的建立方式有如下三種:

直接繼承於ViewComponent給類加上ViewComponent特性,或繼承於帶有ViewComponent特性的類建立一個類,類名以ViewComponent結尾

和Controller一樣,View Component必須是public的,不能嵌套,不能是抽象類別。

舉例來說,我們建立一個View Component,類名為TopListViewComponent,代碼如下:

public class TopListViewComponent : ViewComponent{ private readonly ApplicationDbContext db; public TopListViewComponent(ApplicationDbContext context) { db = context; } public IViewComponentResult Invoke(int categoryId, int topN) { List<string> col = new List<string>(); var items = db.TodoItems.Where(x => x.IsDone == false &&      x.categoryId == categoryId).Take(topN); return View(items); }}

上述類,也可以定義成如下這樣:

[ViewComponent(Name = "TopList")]public class TopWidget{ // 其它類似}

通過在TopWidget類上定義一個名稱為TopList的ViewComponent特性,其效果和定義TopListViewComponent類一樣,系統在尋找的時候,都會認可,並且在其建構函式中通過依賴注入功能提示建構函式中參數的類型執行個體。

Invoke方法是一個約定方法,可以傳入任意數量的參數,系統也支援InvokeAsync方法實現非同步功能。

View Component的視圖檔案建立

以在ProductController的視圖裡調用View Component為例,我們需要在Views\Product檔案夾下建立一個名稱為Components的檔案夾(該檔案夾名稱必須為Components)。

然後在Views\Product\Components檔案夾下建立一個名稱為TopList 的檔案夾(該檔案夾名稱必須和View Component名稱一致,即必須是TopList)。

Views\Product\Components\TopList檔案夾下,建立一個Default.cshtml視圖檔案,並添加如下標記:

@model IEnumerable<BookStore.Models.ProductItem><h3>Top Products</h3><ul> @foreach (var todo in Model) { <li>@todo.Title</li> }</ul>

如果再View Component中,沒有指定視圖的名稱,將預設為Default.cshtml視圖。

至此,該View Component就建立好了,你可以在Views\Product\index.cshtml視圖中的任意位置調用該View Component,比如:

 <div class="col-md-4"> @Component.Invoke("TopList", 1, 10)  </div>

如果在上述TopListViewComponent中定義的是非同步方法呼叫InvokeAsync的話,則可以使用@await Component.InvokeAsync()方法來調用,這兩個方法的第一個參數都是TopListViewComponent的名稱,剩餘的參數則是在TopListViewComponent類中定義的方法參數。

注意:一般來說,View Component的視圖檔案都是添加在Views\Shared檔案夾的,因為一般來說ViewComponent不會特定於某個Controller。

使用自訂視圖檔案

一般來說,如果要使用自訂檔案,我們需要在Invoke的方法返回傳回值的時候來指定視圖的名稱,樣本如下:

return View("TopN", items);

那麼,就需要建立一個Views\Product\Components\TopN.cshtml檔案,而使用的時候則無需更改,還是指定原來的View Component名稱即可,比如:

@await Component.InvokeAsync("TopList", 1, 10) //以非同步呼叫為例

總結

一般來說,建議在通用的功能上使用View Component的功能,這樣所有的視圖檔案都可以放在Views\Shared檔案夾了。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.