欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ASP.NET Core MVC在視圖中使用依賴注入

 更新時間:2022年04月14日 14:59:05   作者:Ruby_Lu  
這篇文章介紹了ASP.NET Core MVC在視圖中使用依賴注入的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

ASP.NET Core 支持在試圖中使用依賴注入。這將有助于提供視圖專用的服務,比如本地化或者僅用于填充視圖元素的數(shù)據(jù)。應盡量保持控制器和視圖之間的關注點分離。視圖所顯示的大部分數(shù)據(jù)應該從控制器傳入。

使用 @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.填充查找數(shù)據(jù)

視圖注入有助于填充 UI 元素,例如下拉框列表。比如一個包括性別,州以及其他用戶資料的表單。如果通過標準的 MVC 方式渲染這個表單,則需要控制器為每一組選項都請求數(shù)據(jù)訪問服務,然后將每一組綁定的選項填充到模型或ViewBag中。

另一種則是直接將服務注入到視圖中以獲取這些選項數(shù)據(jù)。這種方法將控制器代碼量減少到最少,把構造視圖元素的邏輯移到視圖本身去。控制器 Action 只需把用戶資料數(shù)據(jù)傳個表單即可。

2.重寫服務

除了注入服務外,此技術還可用于重寫頁面上先前注入的服務。例如,替換默認的HTML Helper:

@model MVCTest.Models.Operation
@using MVCTest.Services
@inject BaseInfoServices BaseInfoServices
@inject MyHtmlHelper Html

在視圖中使用 @Html 將會調用自定義的服務。

如果想要擴展現(xiàn)有服務而不是替換,則只需在使用此技術的同時,讓服務繼承或者封裝已有實現(xiàn)即可。

到此這篇關于ASP.NET Core MVC在視圖中使用依賴注入的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論