加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

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

发布时间:2020-12-16 00:29:03 所属栏目:asp.Net 来源:网络整理
导读:我有一个布尔属性IsActive。在视图中是具有其属性的对象列表(包括IsActive)。但在列表中,IsActive是一个不可编辑的复选框,因为它是布尔值。如果我将DisplayFor()更改为DisplayTextFor(),那么它只会显示True或false,而不是复选框。如果将Active和false更
我有一个布尔属性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对任何具有此注释的布尔,并将根据具有匹配名称的显示模板进行格式化。通过一些调整,您可以将颜色更改样式直接放置在显示模板中。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读