asp.net – 更改Html.DisplayFor布尔复选框MVC

前端之家收集整理的这篇文章主要介绍了asp.net – 更改Html.DisplayFor布尔复选框MVC前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个布尔属性IsActive。在视图中是具有其属性的对象列表(包括IsActive)。但在列表中,IsActive是一个不可编辑的复选框,因为它是布尔值。如果我将DisplayFor()更改为DisplayTextFor(),那么它只会显示True或false,而不是复选框。如果将Active和false更改为“Active”和“Inactive”,其中Active为真,Inactive为false,
@Html.DisplayTextFor(modelItem => item.IsActive)

然后我将“活跃”变为绿色,“不活跃”为红色

解决方法

您可以使用显示模板格式化显示属性的方式。

在〜/ Shared下或在View文件夹中创建一个DisplayTemplates文件夹,其中将使用该模板的视图。

将新的部分视图添加到此文件夹。命名任何你想要的,例如IsActive.cshtml

@model bool
@if (Model == true)
{
    @Html.Encode("Active")
}
@if (Model == false)
{
    @Html.Encode("Inactive")
}

现在,添加数据注释到您的属性,让它知道使用这个显示模板。

[UIHint("IsActive")]
public bool IsActive { get; set; }

使用Html.DisplayFor对任何具有此注释的布尔,并将根据具有匹配名称显示模板进行格式化。通过一些调整,您可以将颜色更改样式直接放置在显示模板中。

猜你在找的asp.Net相关文章