在MVC Razor视图中,我正在尝试格式化DateTime字段以仅显示时间。使用下面的代码我收到错误“模板只能用于字段访问,属性访问,单维数组索引或单参数自定义索引器表达式。”
<td>@(Html.DisplayFor(m=>row.LastUpdatedDate.ToString("HH:mm:ss")))</td>
请问有什么问题导致此错误以及如何解决?
感谢您的帮助。
答案 0 :(得分:16)
我遇到了同样的问题,我已经解决了这个问题。 如果您想将“LastUpdatedDate”转换为特定格式,那么您可以尝试:
@Html.TextBoxFor(m=>row.LastUpdatedDate,
new { @Value = Convert.ToString(row.LastUpdatedDate.ToShortDateString()) })
答案 1 :(得分:14)
DisplayFor需要一个表达式,用于标识包含要显示的属性的对象。它将使用内置或自定义模板来呈现该显示。您试图将显示逻辑提供为表达式参数,该参数无效。
使用
@String.Format("HH:mm:ss", Model.row.LastUpdateDate)
或
@Model.row.LastUpdateDate.ToString("HH:mm:ss")
答案 2 :(得分:2)
另一种可能的方法是使用扩展方法来实现相同的目标。使用该方法,您将不会使用硬编码格式填充视图。
扩展方法
/// <summary>
/// Converts a DateTime string to Date string. Also if Date is default value i.e. 01/01/0001
/// then returns String.Empty.
/// </summary>
/// <param name="inputDate">Input DateTime property </param>
/// <param name="showOnlyDate">Pass true to show only date.
/// False will keep the date as it is.</param>
/// <returns></returns>
public static string ToString(this DateTime inputDate, bool showOnlyDate)
{
var resultDate = inputDate.ToString();
if (showOnlyDate)
{
if (inputDate == DateTime.MinValue)
{
resultDate = string.Empty;
}
else
{
resultDate = inputDate.ToString("dd-MMM-yyyy");
}
}
return resultDate;
}
查看强>
@Model.LastUpdateDate.ToString(true).
答案 3 :(得分:1)
你有一个非常简单的方法可以解决这个问题,你可能不止一次遇到这个问题。
要了解发生了什么,您将传递方法作为参数。相反,你应该传递一个表达式。
而不是这样做
<td>@(Html.DisplayFor(m=>row.LastUpdatedDate.ToString("HH:mm:ss")))</td>
你应该做
var date = row.LastUpdatedDate.ToString("HH:mm:ss")
<td>@Html.DisplayFor(m=> date)</td>
答案 4 :(得分:0)
而不是TextBoxFor使用TextBox并在值字段中指定格式,即
@Html.TextBox("textboxName", Model.dateName.ToString("MMM dd yyyy"))
使用bootstrap datepicker,它看起来像:
<div class="input-group date datetime col-md-8 col-xs-7" data-min-view="2" data-date-format="M dd yyyy">
@Html.TextBox("closeDate", Model.closeDate.ToString("MMM dd yyyy"), new { @class = "form-control", @readonly = "readonly", size = "16", placeholder = Lang.Label_closeDate })
<span class="input-group-addon btn btn-primary">
<span class="glyphicon glyphicon-th"></span>
</span>
</div>