1.视图组件介绍

  视图组件是 ASP.NET Core MVC 的新特性,类似于局部视图,但它更强大。视图组件不使用模型绑定,并且仅依赖于调用它时所提供的数据。

  视图组件特点:

    呈块状,而不是整个响应

    包括在控制器和视图之间发现的相同的关注点和可测试性优点

    可以拥有参数和业务逻辑

    通常从布局页面调用

  视图组件可以用在任何需要重复逻辑且对局部视图来说过于复杂的情况,例如:

    动态导航菜单

    标签云(需要查询数据库)

    登录面板

    购物车

    最近发表的文章

    典型博客上的侧边栏内容

    将在每个页面上呈现的登录面板,根据用户的登录状态显示注销或者登录的链接

  视图组件有两部分组成,类(通常派生自 ViewComponent)和它返回的结果(通常是一个视图)。与控制器一样,视图组件可以是POCO,但大多数是利用 ViewComponent 派生的方法和属性。

2.创建视图组件

  (1)视图组件类

  一个视图组件类通常可以通过以下任一方式创建:

    派生自ViewComponent

    使用 [ViewComponent] 属性装饰类,或从具有 [ViewComponent] 属性的类派生

    创建一个名称后缀为 ViewComponent 结尾的类

  像控制器一样,视图组件必须是 public ,非嵌套和非抽象类。视图组件名称是删除了 ViewComponent 后缀的类名,可以使用 ViewComponentAttribute.Name 属性显示指定。

  

  视图组件类优点:

    完全支持构造函数依赖注入

    不参与控制器生命周期,这意味着不能在视图组件中使用过滤器

  (2) 视图组件方法

  视图组件在 InvokeAsync 方法中定义其逻辑,并返回 IViewComponentResult 。参数直接来自视图组件的调用,而不是来自模型绑定。视图组件从不直接处理请求。通常,视图组件通过调用 View 方法初始化模型并将其传递给视图。总之,视图组件有以下特点:

    定义一个 InvokeAsync 方法并返回 IViewComponentResult。

    通常通过调用  ViewComponent View 方法初始化模型并将其传递给视图。

    参数来自调用方法,而不是 HTTP,没有模型绑定。

    不能直接作为 HTTP 端点访问,它是从你的代码(通常在视图中)调用的。视图组件不处理请求。

    在签名上重载,而不是当前 HTTP 请求的任何细节。

  (3) 视图搜索路径

  运行时在以下路径搜索视图:

  Views/<controller_name>/Components/<view_component_name>/<view_name>

  Views/Shared/Components/<view_component_name>/<view_name>

  视图组件的默认视图名称是 Default,这意味着你的视图文件通常名为 Default.cshtml。你可以在创建视图组件结果或调用 View 方法时指定其他的视图名称。

3.调用视图组件

   要使用视图组件,请从视图中调用  @Component.InvokeAsync("视图组件名称",<匿名参数>)。参数将传递到 InvokeAsync 方法。如下:

@await Component.InvokeAsync("TopicRankList",new { days=5})

  视图组件通常从视图中调用,但也可以从控制器方法中直接调用,虽然视图组件不像控制器那样定义终结点。

        public ActionResult Index()
{
return ViewComponent("TopicRankList", new { days = });
}

4.实战视图组件

  添加一个 ViewCompoents 文件夹,然后添加 UserRankList类:

    public class UserRankList : ViewComponent
{
private readonly DataContext _db;
private IMemoryCache _memoryCache;
private string cacheKey = "topicrank"; public UserRankList(DataContext db, IMemoryCache memoryCache)
{
_db = db;
_memoryCache = memoryCache;
} public IViewComponentResult Invoke(int days)
{
var items = new List<User>();
if (!_memoryCache.TryGetValue(cacheKey, out items))
{
items = GetRankUsers(, days);
}
_memoryCache.Set(cacheKey,items,TimeSpan.FromMinutes());
return View(items);
} private List<User> GetRankUsers(int top, int days)
{
return _db.User.OrderBy(o => o.Id).Take(top).ToList();
}
}

  视图组件类可以在项目的任何文件夹中。 [ViewComponent] 特性可以更改用于引用视图组件的名称,例如,可以命名类为 XYZ,并应用 [ViewComponent] 特性:

[ViewComponent(Name="UserRankTop")]
public calss XYZ:ViewComponent

  Invoke 方法返回列表,然后创建视图组件视图。

  创建 View/Shared/Components 文件夹。这个文件夹必须名为 Components。然后在里面创建 UserRankList 文件夹,添加 Default.cshtml 视图:

@model List<MVCTest.Models.User>

<h2>user</h2>
<div class="list-group">
@foreach (var item in Model)
{
<label>@item.Name</label>
}
</div>

  最后在视图中调用:@await Component.InvokeAsync("UserRankList", new { days=5})

最新文章

  1. 当前Windows群集心跳阀值设置
  2. 【笔记】InnoDB内存分配
  3. BZOJ 1670: [Usaco2006 Oct]Building the Moat护城河的挖掘
  4. C++和C#混合编程
  5. Android--多线程之Handler(转)
  6. Java最常用的变量定义汇总
  7. JavaScript:表单验证模型
  8. cocos2dx Sprite setBlendFunc 使用颜色混合:加算,减算
  9. java web的一些特殊用法(一)
  10. Qt知识点、疑难杂症的治疗
  11. POJ 2044 Weather Forecast
  12. .NET(C#):XML序列化时派生类的处理
  13. centOS 6 服务管理与服务脚本
  14. Linux基础命令讲解(一)
  15. Redis - NoSQL数据库技术(一)
  16. 解决 win10 新建文件夹重命名卡死的另一种方法
  17. ram自己写?用IP?
  18. js去掉某一属性
  19. poj3278 Catch That Cow(简单的一维bfs)
  20. sql 中常见的控制流语句

热门文章

  1. hive 之 Cube, Rollup介绍
  2. 分布式个人理解概述和dubbo实现简述
  3. 并发编程-concurrent指南-信号量Semaphore
  4. 多线程与高并发(四)volatile关键字
  5. 利用HtmlAgilityPack插件写的一个抓取指定网页的图片 第一次写 很乱 随便看看就行
  6. 通过Spring整合hibernate并进行单元测试(详细)
  7. Windows下GIT的使用方法
  8. 2. Django每日一码 之as_view() 源码
  9. 《Predict Anchor Links across Social Networks via an Embedding Approach》阅读笔记
  10. MyBatis从入门到精通(十三):使用discriminator鉴别器映射