国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

解讀ASP.NET 5 & MVC6系列(14):View Component

2019-11-17 02:07:50
字體:
來源:轉載
供稿:網友

解讀asp.net 5 & MVC6系列(14):View Component

2015-05-29 09:18 by 湯姆大叔, ... 閱讀, ... 評論, 收藏, 編輯

在之前的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類的創建方式有如下三種:

  1. 直接繼承于ViewComponent
  2. 給類加上ViewComponent特性,或繼承于帶有ViewComponent特性的類
  3. 創建一個類,類名以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文件夾了。

同步與推薦

本文已同步至目錄索引:解讀ASP.NET 5 & MVC6系列


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 九寨沟县| 寻乌县| 嵊州市| 正蓝旗| 丹东市| 荔浦县| 泸溪县| 陇南市| 延吉市| 镇远县| 沾益县| 亚东县| 游戏| 休宁县| 哈巴河县| 利辛县| 闵行区| 磐石市| 乌鲁木齐市| 日土县| 滦平县| 莱阳市| 九龙城区| 益阳市| 克东县| 中江县| 阳西县| 甘孜县| 清水县| 太原市| 延长县| 垦利县| 额尔古纳市| 达州市| 南召县| 北京市| 黑山县| 沧源| 荃湾区| 汉源县| 奉新县|