婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 解讀ASP.NET 5 & MVC6系列教程(14):View Component

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

熱門標簽:聯通官網400電話辦理 臨沂智能電話機器人加盟 地圖標注軟件免費下載 400電話辦理怎么樣 蘇州如何辦理400電話 西寧呼叫中心外呼系統線路商 百應電話機器人外呼系統 外呼電話機器人成本 網絡電話外呼系統上海

在之前的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)
 {
 Liststring> col = new Liststring>();
 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 IEnumerableBookStore.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系列教程(16):自定義View視圖文件查找邏輯
  • Asp.net mvc在view中用C#代碼動態創建元素

標簽:中衛 清遠 聊城 臨夏 甘肅 慶陽 海西 平涼

巨人網絡通訊聲明:本文標題《解讀ASP.NET 5 & MVC6系列教程(14):View Component》,本文關鍵詞  解讀,ASP.NET,amp,MVC6,系列,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《解讀ASP.NET 5 & MVC6系列教程(14):View Component》相關的同類信息!
  • 本頁收集關于解讀ASP.NET 5 & MVC6系列教程(14):View Component的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩一区中文字幕| 精品理论电影在线观看 | 国产成人精品亚洲777人妖| 欧美日韩一卡二卡三卡| 亚洲成av人片| 欧美老女人第四色| 黑人巨大精品欧美一区| 国产偷v国产偷v亚洲高清| 激情小说亚洲一区| 欧美激情一二三区| 欧美自拍偷拍午夜视频| 人人狠狠综合久久亚洲| 久久亚区不卡日本| 色综合久久天天| 日韩av中文在线观看| 久久久久久久久伊人| 91丝袜国产在线播放| 亚洲成人免费看| 久久青草欧美一区二区三区| 狠狠网亚洲精品| 亚洲天堂精品视频| 精品国产91亚洲一区二区三区婷婷 | 麻豆精品新av中文字幕| 日本一区二区三区视频视频| 欧美日韩亚洲国产综合| 精品一区二区三区久久| 亚洲综合精品久久| 欧美日韩精品福利| 不卡电影一区二区三区| 同产精品九九九| 国产精品久久福利| 日韩一区二区三区四区五区六区| 成人av免费观看| 久久99热99| 日韩在线一区二区三区| 国产精品久久毛片| 精品99一区二区三区| 欧美日韩免费观看一区三区| 久草热8精品视频在线观看| 玉米视频成人免费看| 国产婷婷色一区二区三区在线| 欧美日韩一区高清| 在线影视一区二区三区| 成人免费高清在线| 国产成人免费网站| 精品一区二区免费视频| 麻豆91在线播放| 香蕉久久一区二区不卡无毒影院 | 天堂成人免费av电影一区| 欧美国产日韩一二三区| 欧美成人一区二区三区在线观看| 在线播放欧美女士性生活| 91麻豆国产福利精品| 精品一区二区免费在线观看| 自拍av一区二区三区| 亚洲va在线va天堂| 亚洲视频 欧洲视频| 国产精品亲子伦对白| 久久综合网色—综合色88| 欧美日韩视频在线观看一区二区三区 | 在线亚洲精品福利网址导航| 丁香婷婷综合激情五月色| 岛国av在线一区| av亚洲精华国产精华| www.久久久久久久久| 国产一区二区三区蝌蚪| 国产成人自拍在线| 成人免费毛片片v| 日本伦理一区二区| 欧美日韩一级片在线观看| 欧美日韩在线综合| 欧美一区二区三区在线看| 欧美成人猛片aaaaaaa| 日韩一区二区三区四区| 久久精品一区二区三区四区| 欧美国产精品中文字幕| 亚洲精品国产高清久久伦理二区| 亚洲一区二区三区四区不卡| 一区二区三区蜜桃网| 一区二区三区四区在线免费观看| 亚洲图片欧美一区| 国产一区高清在线| 91麻豆免费看片| 91精品国产一区二区人妖| 精品国产乱码久久久久久久 | 91免费观看在线| 91在线观看美女| 欧美日韩精品欧美日韩精品一| 精品国产第一区二区三区观看体验| 久久影院午夜片一区| 一区二区视频在线| 日本免费新一区视频| jiyouzz国产精品久久| 日韩天堂在线观看| 精品国产乱码久久久久久影片| 国产精品二三区| 久久黄色级2电影| 成人午夜精品一区二区三区| www.视频一区| 91精品国产麻豆| 日韩一区有码在线| 九九精品视频在线看| 91精品1区2区| 久久精品亚洲乱码伦伦中文| 亚洲综合免费观看高清完整版| 国产精品一区二区久久不卡 | 亚洲图片欧美一区| 国产在线一区二区综合免费视频| 91首页免费视频| 欧美xfplay| 五月天视频一区| 97久久超碰国产精品电影| 日韩三级在线观看| 一区二区三区在线视频播放| 国产成人丝袜美腿| 久久尤物电影视频在线观看| 午夜精品视频一区| 色就色 综合激情| 国产精品沙发午睡系列990531| 亚洲柠檬福利资源导航| 国产精品香蕉一区二区三区| 欧美一区二区视频在线观看2020| 亚洲一区二区视频| 91高清视频在线| 亚洲精品少妇30p| 色综合亚洲欧洲| 成人欧美一区二区三区在线播放| 不卡视频一二三四| 国产欧美日产一区| 成人免费视频一区| 久久久精品影视| 国产suv精品一区二区三区| 91久久精品一区二区| 亚洲精品少妇30p| 日本高清免费不卡视频| 一区二区三区产品免费精品久久75| 成人一级片在线观看| 国产精品久久久久aaaa| 91久久一区二区| 亚洲国产aⅴ天堂久久| 欧美日韩不卡一区二区| 亚洲成a天堂v人片| 欧美一区2区视频在线观看| 日本欧美在线观看| 久久久久久久性| 蜜臀av在线播放一区二区三区| 欧美男男青年gay1069videost| 午夜精品久久久久久久久久久| 9191成人精品久久| 美女一区二区久久| 国产日韩欧美亚洲| 91在线视频观看| 视频一区二区国产| 久久久精品国产免大香伊| 99久久精品免费| 午夜久久久影院| 国产色一区二区| 日本福利一区二区| 免费一级欧美片在线观看| 欧美人狂配大交3d怪物一区| 麻豆国产精品视频| 国产精品色呦呦| 欧美一级生活片| 国产成人综合在线播放| 一区二区三区国产精华| 欧美福利视频一区| 风间由美一区二区三区在线观看| 亚洲欧美视频在线观看| 日韩一区二区三区高清免费看看 | 香蕉成人啪国产精品视频综合网| 欧美人xxxx| 国产精品综合视频| 亚洲一区二区中文在线| 精品国产免费视频| 一本到高清视频免费精品| 蜜臀av性久久久久av蜜臀妖精 | 亚洲国产综合在线| 精品99999| 欧美性三三影院| 风间由美一区二区av101| 免费观看30秒视频久久| 亚洲黄色av一区| 18成人在线观看| 亚洲国产精华液网站w| 日韩一区二区免费视频| 国产精品中文字幕日韩精品| 三级亚洲高清视频| 一区二区三区成人在线视频| 国产精品欧美一级免费| 欧美一级久久久| 欧美日韩一二三区| 91国偷自产一区二区三区成为亚洲经典 | 91成人在线精品| 麻豆精品在线视频| 亚洲成a人片在线不卡一二三区| 国产精品久久夜| 国产精品高清亚洲| 久久久蜜臀国产一区二区| 欧美一区二区精品久久911| 欧美视频在线一区二区三区|