<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網 責編:小采 時間:2020-11-27 22:37:03
        文檔

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

        解讀ASP.NET 5 & MVC6系列教程(14):View Component:在之前的MVC中,我們經常需要類似一種小部件的功能,通常我們都是使用Partial View來實現,因為MVC中沒有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版MVC6中,提供了一種叫做View Component的功能。 你可
        推薦度:
        導讀解讀ASP.NET 5 & MVC6系列教程(14):View Component:在之前的MVC中,我們經常需要類似一種小部件的功能,通常我們都是使用Partial View來實現,因為MVC中沒有類似Web Forms中的WebControl的功能。但在MVC6中,這一功能得到了極大的改善。新版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,代碼如下:

        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文件夾了。

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

        文檔

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

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

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲高清毛片一区二区| 国产亚洲精品精华液| 91香蕉视频免费| 日韩免费无砖专区2020狼| 国产成人免费a在线资源| 国产亚洲人成无码网在线观看| 高潮毛片无遮挡高清免费视频| 成在人线av无码免费高潮喷水| 曰批全过程免费视频网址| 国产男女猛烈无遮挡免费网站| 亚洲色成人四虎在线观看| 国产高清对白在线观看免费91| 一个人免费日韩不卡视频| 国产精品免费看久久久无码| 亚洲heyzo专区无码综合| 免费看国产一级片| 亚洲一级毛片在线播放| 一级特黄录像视频免费| 成年18网站免费视频网站| 亚洲日本乱码在线观看| 亚洲熟妇久久精品| 免费a在线观看播放| 精品亚洲A∨无码一区二区三区| 美女黄网站人色视频免费| 久久精品亚洲福利| 亚洲精品国产综合久久久久紧| 哒哒哒免费视频观看在线www| 国产日韩在线视频免费播放| 日韩精品电影一区亚洲| 亚洲熟妇成人精品一区| 日韩亚洲国产综合久久久| 在线观看肉片AV网站免费| 波多野结衣亚洲一级| 18禁止看的免费污网站| 亚洲精品国产摄像头| 亚洲男人天堂2020| 国产精品亚洲一区二区三区| 特级做A爰片毛片免费69| 一级a性色生活片久久无少妇一级婬片免费放 | 久久九九免费高清视频| 亚洲伊人久久大香线焦|