分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 软件开发

Asp.net core 学习笔记 ( ViewComponent 组件 )

发布时间:2023-09-06 01:21责任编辑:傅花花关键词:组件

refer : https://docs.microsoft.com/en-us/aspnet/core/mvc/views/view-components

core 和 Angular 的 component 是不同的. 

core 的 component 只是对 partial view 的升级而已.

从前 partial view 只是一个 view 的封装, component 则是 controller + view 的封装 

所以方便一些. 

首先定义一个 class 继承 ViewComponent, component 的名字就是 class name, 当然我们也可以改它, 

[Area("Web")][ViewComponent(Name = "keatkeat")] //修改 name public class MyHeader : ViewComponent{ ???private DB db { get; set; } ???public MyHeader( ???????DB db ???) ???{ ???????this.db = db; ???} ???public Task<IViewComponentResult> InvokeAsync(string value) //调用时可以传参哦 ????{ ???????var vm = new ViewModel ???????{ ???????????name = value ???????}; ???????return Task.FromResult<IViewComponentResult>(View(vm)); ???}}

调用 

@addTagHelper *, Project

@{ var value = "keatkeat87"; }@await Component.InvokeAsync("keatkeat",value)@await Component.InvokeAsync(nameof(Project.Web.ViewComponents.MyHeader.MyHeader),value)<vc:keatkeat value="@value" ></vc:keatkeat>

上面有 3 种调用的方式 

第一种是写入 component 名字 

第二种是通过 nameof 找到 class, 如果你修改了名字, 那么这个调用是会坏掉的哦. 

第三种是通过 element 模式 (需要在 _ViewImports.cshtml 添加 @addTagHelper *, Project,  Project 是我项目的名字, 直接放整个项目 assembly 就可以了)

ViewComponent 的模板和一般的 controller 查找不同, 一般的 controller View name 是 Index.cshtml 

而 ViewComponent 则是 Components/ComponentName/Default.cshtml 

Asp.net core 学习笔记 ( ViewComponent 组件 )

原文地址:http://www.cnblogs.com/keatkeat/p/7749315.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved