国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 22:37:03
文檔

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

解讀ASP.NET 5 & MVC6系列教程(14):View Component:在之前的MVC中,我們經(jīng)常需要類似一種小部件的功能,通常我們都是使用Partial View來實(shí)現(xiàn),因為MVC中沒有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版MVC6中,提供了一種叫做View Component的功能。 你可
推薦度:
導(dǎo)讀解讀ASP.NET 5 & MVC6系列教程(14):View Component:在之前的MVC中,我們經(jīng)常需要類似一種小部件的功能,通常我們都是使用Partial View來實(shí)現(xiàn),因為MVC中沒有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版MVC6中,提供了一種叫做View Component的功能。 你可

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

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

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

View Component的創(chuàng)建

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

直接繼承于ViewComponent給類加上ViewComponent特性,或繼承于帶有ViewComponent特性的類創(chuàng)建一個類,類名以ViewComponent結(jié)尾

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

舉例來說,我們創(chuàng)建一個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類一樣,系統(tǒng)在查找的時候,都會認(rèn)可,并且在其構(gòu)造函數(shù)中通過依賴注入功能提示構(gòu)造函數(shù)中參數(shù)的類型實(shí)例。

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

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

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

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

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

@model IEnumerable<BookStore.Models.ProductItem>

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

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

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

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

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

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

使用自定義視圖文件

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

return View("TopN", items);

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

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

總結(jié)

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

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

解讀ASP.NET 5 & MVC6系列教程(14):View Component:在之前的MVC中,我們經(jīng)常需要類似一種小部件的功能,通常我們都是使用Partial View來實(shí)現(xiàn),因為MVC中沒有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版MVC6中,提供了一種叫做View Component的功能。 你可
推薦度:
標(biāo)簽: &amp; ): view
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 8x成人在线 | 最近免费中文字幕大全免费版视频 | 97精品国产91久久久久久久 | 免费看真人a一级毛片 | 国产一区二区高清 | 99热成人精品免费久久 | 久久亚洲精品中文字幕60分钟 | 欧美另类精品一区二区三区 | 国产精品视频免费一区二区三区 | 亚洲福利视频 | 97久久综合区小说区图片专区 | 亚洲国产婷婷综合在线精品 | 国产在线观看不卡 | 91发布页 | 天码毛片一区二区三区入口 | 日韩欧美中文 | 国产在线精品一区二区三区 | 亚洲一区二区在线免费观看 | 日本天堂在线 | 91欧美激情一区二区三区成人 | 青草九九 | 国内精品久久久久影院不卡 | 99热成人精品国产免国语的 | 久久精品亚洲一区二区 | 伊人久久综合成人网小说 | 欧美日韩中文字幕 | 欧美日韩大片 | 天天色天天射天天操 | 国产99久久精品一区二区 | 亚洲一区二区三区免费视频 | 久久伊人精品一区二区三区 | 国产在线精品观看一区 | 日韩在线1| 人人草视频在线观看 | 色综合91久久精品中文字幕 | 欧美日韩中文在线 | 国产亚洲精品成人婷婷久久小说 | 成人久久精品 | 欧美性一区二区三区五区 | 毛片综合| 欧美日韩亚洲综合另类ac |