一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - 解讀ASP.NET 5 & MVC6系列教程(14):View Component

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

2020-01-16 15:36湯姆大叔 ASP.NET教程

這篇文章主要介紹了ASP.NET 5 MVC6 中View Component創建和視圖的使用,需要的朋友可以參考下

在之前的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,代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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);
 }
}

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

?
1
2
3
4
5
[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視圖文件,并添加如下標記:

?
1
2
3
4
5
6
7
8
9
@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,比如:

?
1
2
3
<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的方法返回返回值的時候來指定視圖的名稱,示例如下:

 

?
1
return View("TopN", items);

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

 

?
1
@await Component.InvokeAsync("TopList", 1, 10) //以異步調用為例

總結

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 婷婷久久综合九色综合九七 | 亚洲黄色小视频 | 男人女人插 | 毛片免费在线视频 | 国产精品青青青高清在线密亚 | 99久久免费精品视频 | 亚洲乱亚洲23p女 | 国产欧美精品专区一区二区 | 免费xxxxx大片在线观看影视 | 亚欧精品在线观看 | 91精品久久国产青草 | 日本高清有码视频 | 精品综合一区二区三区 | 国产一区日韩二区欧美三 | 精品一区二区视频 | 网址在线观看你懂我意思吧免费的 | 91精品91| 大陆黄色片 | 国产一级一级一级成人毛片 | 免费观看欧美一级高清 | 国产视频一区 | 欧美一区二区三区视视频 | 国产精品一级香蕉一区 | 九九精品视频在线观看九九 | 动漫美女被吸乳 | 国产精品片| 吃瓜视频在线观看 | voyeur多毛厕所| 日本精a在线观看 | 女人被爽到呻吟娇喘的视频动态图 | 红色毛片| 奇米影视中文字幕 | 欧美精品一区二区三区免费 | 久久免费国产 | 成人免费影院 | 免费一级特黄特色大片 | 婷综合 | 农村妇女野战bbxxx | 久久久久久久99精品免费观看 | 97久久免费视频 | 婚前试爱免费观看 |