ASP.NET Core MVC在视图中使用依赖注入
ASP.NET Core 支持在试图中使用依赖注入。这将有助于提供视图专用的服务,比如本地化或者仅用于填充视图元素的数据。应尽量保持控制器和视图之间的关注点分离。视图所显示的大部分数据应该从控制器传入。
使用 @inject 指令将服务注入到视图,语法 @inject <type> <name>,例如:
@model MVCTest.Models.Operation @using MVCTest.Services @inject BaseInfoServices BaseInfoServices @{ ViewData["Title"] = "Create"; } <ul> @foreach (var city in BaseInfoServices.GetCities()) { <li>@city</li> } </ul>
public class BaseInfoServices { public List<string> GetCities() { return new List<string>(); } }
需要提前在 ConfigureServices 中配置,将该服务加入到容器。
1.填充查找数据
视图注入有助于填充 UI 元素,例如下拉框列表。比如一个包括性别,州以及其他用户资料的表单。如果通过标准的 MVC 方式渲染这个表单,则需要控制器为每一组选项都请求数据访问服务,然后将每一组绑定的选项填充到模型或ViewBag中。
另一种则是直接将服务注入到视图中以获取这些选项数据。这种方法将控制器代码量减少到最少,把构造视图元素的逻辑移到视图本身去。控制器 Action 只需把用户资料数据传个表单即可。
2.重写服务
除了注入服务外,此技术还可用于重写页面上先前注入的服务。例如,替换默认的HTML Helper:
@model MVCTest.Models.Operation @using MVCTest.Services @inject BaseInfoServices BaseInfoServices @inject MyHtmlHelper Html
在视图中使用 @Html 将会调用自定义的服务。
如果想要扩展现有服务而不是替换,则只需在使用此技术的同时,让服务继承或者封装已有实现即可。
到此这篇关于ASP.NET Core MVC在视图中使用依赖注入的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
asp.net中Fine Uploader文件上传组件使用介绍
最近在处理后台数据时需要实现文件上传.考虑到对浏览器适配上采用Fine Uploader. Fine Uploader 采用ajax方式实现对文件上传.同时在浏览器中直接支持文件拖拽[对浏览器版本有要求类似IE版本必须是9或是更高的IE10].2013-01-01在ASP.NET使用JavaScript显示信息提示窗口实现原理及代码
在ASP.NET使用JavaScript显示信息窗口,感兴趣的朋友可以了解一下,本文将介绍详细的操作步骤,希望对你的JavaScript知识巩固有所帮助2013-01-01.NET读写Excel工具Spire.Xls使用 对数据操作与控制(4)
这篇文章主要为大家详细介绍了.NET读写Excel工具Spire.Xls使用,对数据操作与控制的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-11-11MVC使用Memcache+Cookie解决分布式系统共享登录状态学习笔记6
这篇文章主要介绍了MVC使用Memcache+Cookie解决分布式系统共享登录状态学习笔记,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2016-09-09
最新评论