成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

移動(dòng)開發(fā) Android
在之前的MVC中,我們經(jīng)常需要類似一種小部件的功能,通常我們都是使用Partial View來(lái)實(shí)現(xiàn),因?yàn)镸VC中沒(méi)有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版MVC6中,提供了一種叫做View Component的功能。

 在之前的MVC中,我們經(jīng)常需要類似一種小部件的功能,通常我們都是使用Partial View來(lái)實(shí)現(xiàn),因?yàn)镸VC中沒(méi)有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版MVC6中,提供了一種叫做View Component的功能。

你可以將View Component看做是一個(gè)mini的Controller——它只負(fù)責(zé)渲染一小部分內(nèi)容,而非全部響應(yīng),所有Partial View能解決的問(wèn)題,你都可以使用View Component來(lái)解決,比如:動(dòng)態(tài)導(dǎo)航菜單、Tag標(biāo)簽、登錄窗口、購(gòu)物車、最近閱讀文章等等。

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

View Component的創(chuàng)建

目前,View Component類的創(chuàng)建方式有如下三種:

直接繼承于ViewComponent

給類加上ViewComponent特性,或繼承于帶有ViewComponent特性的類

創(chuàng)建一個(gè)類,類名以ViewComponent結(jié)尾

和Controller一樣,View Component必須是public的,不能嵌套,不能是抽象類。舉例來(lái)說(shuō),我們創(chuàng)建一個(gè)View Component,類名為TopListViewComponent,代碼如下:

 

  1. public class TopListViewComponent : ViewComponent 
  2.     private readonly ApplicationDbContext db; 
  3.  
  4.     public TopListViewComponent(ApplicationDbContext context) 
  5.     { 
  6.         db = context; 
  7.     } 
  8.  
  9.     public IViewComponentResult Invoke(int categoryId, int topN) 
  10.     { 
  11.         List col = new List();         var items = db.TodoItems.Where(x => x.IsDone == false &&                                             x.categoryId == categoryId).Take(topN);          return View(items);     } } 
  12.  
  13.   

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

  1. [ViewComponent(Name = "TopList")] 
  2. public class TopWidget 
  3.     // 其它類似 
  4. }

通過(guò)在TopWidget類上定義一個(gè)名稱為TopList的ViewComponent特性,其效果和定義TopListViewComponent類一樣,系統(tǒng)在查找的時(shí)候,都會(huì)認(rèn)可,并且在其構(gòu)造函數(shù)中通過(guò)依賴注入功能提示構(gòu)造函數(shù)中參數(shù)的類型實(shí)例。

Invoke方法是一個(gè)約定方法,可以傳入任意數(shù)量的參數(shù),系統(tǒng)也支持InvokeAsync方法實(shí)現(xiàn)異步功能。

View Component的視圖文件創(chuàng)建

以在ProductController的視圖里調(diào)用View Component為例,我們需要在Views\Product文件夾下創(chuàng)建一個(gè)名稱為Components的文件夾(該文件夾名稱必須為Components)。

然后在Views\Product\Components文件夾下創(chuàng)建一個(gè)名稱為TopList 的文件夾(該文件夾名稱必須和View Component名稱一致,即必須是TopList)。

在Views\Product\Components\TopList文件夾下,創(chuàng)建一個(gè)Default.cshtml視圖文件,并添加如下標(biāo)記:

  1. @model IEnumerable<BookStore.Models.ProductItem> 
  2.  
  3. <h3>Top Products</h3> 
  4. <ul> 
  5.     @foreach (var todo in Model) 
  6.     { 
  7.         <li>@todo.Title</li> 
  8.     } 
  9. </ul> 

如果再View Component中,沒(méi)有指定視圖的名稱,將默認(rèn)為Default.cshtml視圖。

至此,該View Component就創(chuàng)建好了,你可以在Views\Product\index.cshtml視圖中的任意位置調(diào)用該View Component,比如:

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

 

如果在上述TopListViewComponent中定義的是異步方法InvokeAsync的話,則可以使用@await Component.InvokeAsync()方法來(lái)調(diào)用,這兩個(gè)方法的***個(gè)參數(shù)都是TopListViewComponent的名稱,剩余的參數(shù)則是在TopListViewComponent類中定義的方法參數(shù)。

注意:一般來(lái)說(shuō),View Component的視圖文件都是添加在Views\Shared文件夾的,因?yàn)橐话銇?lái)說(shuō)ViewComponent不會(huì)特定于某個(gè)Controller。

使用自定義視圖文件

一般來(lái)說(shuō),如果要使用自定義文件,我們需要在Invoke的方法返回返回值的時(shí)候來(lái)指定視圖的名稱,示例如下:

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

那么,就需要?jiǎng)?chuàng)建一個(gè)Views\Product\Components\TopN.cshtml文件,而使用的時(shí)候則無(wú)需更改,還是指定原來(lái)的View Component名稱即可,比如:

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

總結(jié)

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

責(zé)任編輯:chenqingxiang 來(lái)源: 湯姆大叔的博客
相關(guān)推薦

2015-06-18 16:29:14

ASP.NET

2015-06-17 14:42:04

ASP.NET

2015-06-29 10:00:02

ASP.NETMVC6

2015-06-18 14:13:36

ASP.NET

2015-06-18 17:04:22

ASP.NET

2015-06-16 15:01:59

ASP.NET 5

2015-06-17 16:01:30

ASP.NET

2015-06-17 16:45:28

ASP.NET

2015-06-17 16:04:36

ASP.NET

2015-06-17 17:01:48

ASP.NET

2015-06-17 10:16:30

ASP.NET

2015-06-18 17:37:19

ASP.NET

2015-06-18 17:34:25

ASP.NET

2015-06-17 14:09:36

ASP.NET

2015-06-17 14:16:50

ASP.NET

2015-06-17 14:18:50

ASP.NET

2015-06-18 14:25:56

ASP.NET

2014-08-26 09:22:40

ASP.NET MVCRouting

2015-06-30 14:58:20

技術(shù)周刊

2009-07-24 13:20:44

MVC框架ASP.NET
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 99精品欧美一区二区三区综合在线 | 91免费电影 | 999热精品视频 | 久久国产精品首页 | 爱操影视 | 天天射视频| 中文字幕在线一区 | 91成人精品视频 | 久久电影一区 | 欧美jizzhd精品欧美巨大免费 | 欧美美女二区 | 成人精品一区二区 | 精品视频一区二区三区在线观看 | 精品国产1区2区3区 一区二区手机在线 | 国产乱码精品一区二区三区中文 | 国产精品99久久久精品免费观看 | 神马影院一区二区三区 | 在线观看中文字幕dvd播放 | 欧美精品在线播放 | 中文字幕欧美在线观看 | 亚洲一区二区在线视频 | 亚洲一区二区三区免费观看 | 国产美女一区二区 | 另类在线 | 天天躁人人躁人人躁狂躁 | 国产精品久久久久久福利一牛影视 | 国产情侣激情 | 久久久精品一区二区三区 | 成人免费视频一区二区 | 日p视频免费看 | 草草草久久久 | 中文字幕欧美在线观看 | 夜夜艹| 久久成人国产精品 | 久久免费精品 | 久久久久久综合 | 99re在线播放| 欧美一区二区三区大片 | 欧美片网站免费 | 日本欧美视频 | 91精品国产乱码久久久久久 |