36

次のように、ビューモデルにプロパティがあります。

[Editable(false)]
[Display(Name = "Date")]
[DisplayFormat(DataFormatString = "{0:yyyy/MM/dd}", ApplyFormatInEditMode = true)]
public DateTime MovementDate { get; set; }

それでもマークアップ

<td>
    @Html.DisplayFor(modelItem => item.MovementDate)
</td>

日付値を としてレンダリングします2013/05/15 12:00:00 AM

私は何を間違っていますか?私のモデル:

public class WithDateModel
{
    [DisplayFormat(DataFormatString = "{0:yyyy/MM/dd}")]
    public DateTime TheDate { get; set; }
    public WithDateModel()
    {
        TheDate = DateTime.Now;
    }
}

私の見解:

@model ParkPay.WebTests.Models.WithDateModel
@Html.DisplayFor(m => m.TheDate)
@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}

レンダリングされるもの:

2013/05/25 02:23:37 AM
4

8 に答える 8

45

モデルで動作しない場合は、ビューで試すことができます。

@Html.TextBoxFor(m => m.ValidFrom, "{0:dd/MM/yyyy}", new {maxlength = 10})
于 2014-01-15T10:37:36.390 に答える
12

ApplyFormatInEditMode設定している場合、なぜ使用しています[Editable(false)]か?テキスト ボックスまたは編集用のApplyFormatInEditMode何かに日付がある場合は、日付をフォーマットするだけです。

以下を使用して、日付を正しく表示することができました。

[DisplayFormat(DataFormatString = "{0:yyyy/MM/dd}")]
public DateTime Date 
{
    get
    {
        return DateTime.Now;
    }
    set
    {
        Date = DateTime.Now;
    }
}

およびビューで(結果の出力とともに):

@Html.DisplayFor(x => x.Date)        // 2013/05/23
<br />
@Model.Date                          // 23/05/2013 09:57:56
<br />
@Html.DisplayFor(x => Model.Date)    // 2013/05/23

お役に立てれば。

于 2013-05-23T09:04:59.723 に答える
0

これは私にとってはうまくいきます:

モデルでは:

using System.ComponentModel.DataAnnotations;

namespace Athlete.Models
{
    public class Foo
    {

        [DisplayFormat(DataFormatString = "{0:MM/dd/yyyy}")]
        public DateTime SignDate
        {
           get;
           set;
        }
    }
}

そしてビューで:

<td style="text-align:left;">@Html.DisplayFor(modelItem => item.SignDate)</td>
于 2016-12-02T15:25:30.683 に答える