5

从我的控制器中,我已将值模块传递给查看

    public ActionResult Details(long id, string owner)
    {
        var module = _ownedModuleRepository.GetModuleDetails(id, owner);

        return View(module);
    }

我在视图中显示了它包含的值,如下所示

    <dt>ID</dt>
    <dd>@Model.Id</dd>

    <dt>Module ID</dt>
    <dd>@Model.ModuleId</dd>

     <dt>Owner</dt>
    <dd>@Model.Owner</dd>

    <dt>Module Type</dt>
    <dd>@Model.TypeName</dd>

    <dt>Module Kind</dt>
    <dd>@Model.KindName</dd>

    <dt>Ownership Start Date</dt>
    <dd>@Model.Start</dd>

    <dt>Ownership End Date</dt>
    <dd>@Model.End</dd>

    @foreach (var properties in Model.Properties)
    {
        <dt>Property Name</dt>
        <dd>@properties.Name</dd>
        <dt>Property Value</dt>
        <dd>@properties.Value</dd>
    }

目前@Model.End为空,它是 DateTime 类型,我已在 viewmodel 中将其设置为可为空。因为它是空的,这就是我所看到的

在此处输入图像描述

如您所见,Ownership End Date 的值取自下方的 Property Name 的值。如果@Model.End 为 null,如何将其设置为空?

编辑1:

我的模型

public class OwnedModuleDetails
{
    public long Id { get; set; }

    public string ModuleId { get; set; }

    public string Owner { get; set; }

    public string KindName { get; set; }
    public string TypeName { get; set; }

    public DateTime Start { get; set; }

    public DateTime? End { get; set; }

    public IEnumerable<Property> Properties { get; set; }
}

来自存储库的方法

     public OwnedModuleDetails GetModuleDetails(long id, string owner)
        {
// ReSharper disable ImplicitlyCapturedClosure
            var module = (_dbSis.OwnedModules.Where(t => t.Id == id).Select(m => new OwnedModuleDetails
// ReSharper restore ImplicitlyCapturedClosure
            {
                Id = id,
                ModuleId = m.ModuleId,
                TypeName = m.ModuleType.TypeName,
                KindName = m.ModuleType.ModuleKind.KindName,
                Owner = owner,
                Start = m.Start,
                End = m.End,
                Properties = m.PropertyConfiguration.PropertyInstances.Select(
                    x => new Property { Name = x.Property.Name, Value = x.Value })
            }));

            return (module.FirstOrDefault());
        }
4

4 回答 4

8

尝试添加空格:

<dt>Ownership End Date</dt>
<dd>
    @if (Model.End != null)
    {
        @Model.End
    }
    else
    {
        @:&nbsp;
    }
</dd>
于 2013-07-29T08:17:29.693 回答
4

当用户在日期列中插入空值时,我曾经遇到过这个问题。

导致此错误:

System.InvalidOperationException: Nullable object must have a value

要解决此问题,而不是DisplayFor仅在视图中使用以下代码,因此如果列值为 null,它将显示 Date is Empty

 <td>
            
@(item.Startdate.HasValue ? item.Startdate.Value.ToString("dd/MM/yyyy") : "Date is Empty")

</td>

进一步阅读这个这个模型

希望能帮助某人。

于 2015-04-20T08:23:19.267 回答
1

您可以使用 C# null 合并运算符:

@(Model.End?.ToString("dd/MM/yyyy") ?? "Date is Empty")
于 2018-12-19T05:41:05.083 回答
0

三元运算不会在这里工作:

@(Model.End != null ? Model.End.ToString() : "")
于 2013-07-29T08:02:54.003 回答