ASP.NET Core 支持在試圖中使用依賴注入。這將有助於提供視圖專用的服務,好比本地化或者僅用於填充視圖元素的數據。應儘可能保持控制器和視圖之間的關注點分離。視圖所顯示的大部分數據應該從控制器傳入。spa
使用 @inject 指令將服務注入到視圖,語法 @inject <type> <name>,例如:code
@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 中配置,將該服務加入到容器。blog
1.填充查找數據繼承
視圖注入有助於填充 UI 元素,例以下拉框列表。好比一個包括性別,州以及其餘用戶資料的表單。若是經過標準的 MVC 方式渲染這個表單,則須要控制器爲每一組選項都請求數據訪問服務,而後將每一組綁定的選項填充到模型或ViewBag中。ci
另外一種則是直接將服務注入到視圖中以獲取這些選項數據。這種方法將控制器代碼量減小到最少,把構造視圖元素的邏輯移到視圖自己去。控制器 Action 只需把用戶資料數據傳個表單便可。string
2.重寫服務it
除了注入服務外,此技術還可用於重寫頁面上先前注入的服務。例如,替換默認的HTML Helper:io
@model MVCTest.Models.Operation
@using MVCTest.Services
@inject BaseInfoServices BaseInfoServices
@inject MyHtmlHelper Html
在視圖中使用 @Html 將會調用自定義的服務。class
若是想要擴展示有服務而不是替換,則只需在使用此技術的同時,讓服務繼承或者封裝已有實現便可。容器