<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12
      代碼改變世界

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

      2015-05-29 09:18  湯姆大叔  閱讀(12339)  評論(11)    收藏  舉報

      在之前的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類的創建方式有如下三種:

      1. 直接繼承于ViewComponent
      2. 給類加上ViewComponent特性,或繼承于帶有ViewComponent特性的類
      3. 創建一個類,類名以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文件夾了。

      同步與推薦

      本文已同步至目錄索引:解讀ASP.NET 5 & MVC6系列

      主站蜘蛛池模板: 精品国产性色av网站| 精品人妻伦一二三区久久| 樱花草视频www日本韩国| 亚洲成a人片在线观看中| 国产SM重味一区二区三区| 97一期涩涩97片久久久久久久| 免费大片黄国产在线观看| 国产乱码精品一区二区三区中文| 99精品国产一区二区三区| 日韩国产精品区一区二区| 国产免费高清69式视频在线观看| 欧美变态另类zozo| 亚洲色欲在线播放一区| 国产高清一区二区不卡| 奶头又大又白喷奶水av| 又爽又黄又无遮挡的激情视频| 欧洲国产成人久久精品综合| 亚洲成av人片无码迅雷下载| 国偷自产一区二区三区在线视频 | 田东县| 日韩人妻少妇一区二区三区| 亚洲第一综合天堂另类专| 色偷偷亚洲女人天堂观看| 久久AV中文综合一区二区| 国产精品老熟女一区二区| 亚洲人成网站观看在线观看| 免费观看欧美猛交视频黑人| 国产成人片无码视频在线观看| 中文国产成人精品久久不卡| 国产电影一区二区三区| 亚洲无线看天堂av| 国产午夜福利精品视频| 国产中文字幕在线一区| 人妻体内射精一区二区三区| 日本偷拍自影像视频久久| 特级做a爰片毛片免费看无码| www亚洲精品| 亚洲av成人三区国产精品| 欧美z0zo人禽交另类视频| 日本中文字幕不卡在线一区二区| 国产精品国产高清国产一区|