私はすべて試してみますが、これは動作しませんthis(dd/MM/yyyy)日付形式、これは常にゲートmm/dd/yyyy
[Display(Name = "Release Date")]
[DataType(DataType.DateTime)]
[DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:dd/MM/yyyy}")]
public Nullable<DateTime> release_date { get; set; }
かみそりの眺め
@Html.EditorFor(model => model.release_date)
DateTimeテンプレートを使用します。
@model Nullable<System.DateTime>
@if (Model.HasValue)
{
@Html.TextBox("", String.Format("{0:dd/MM/yyyy}", Model.Value))
}
else
{
@Html.TextBox("", String.Format("{0:dd/MM/yyyy}", DateTime.Now))
}
@{
string name = ViewData.TemplateInfo.HtmlFieldPrefix;
string id = name.Replace(".", "_");
}
<script type="text/javascript">
$(document).ready(function () {
$("#@id").datepicker({
dateFormat: "dd/mm/yy",
showStatus: true,
showWeeks: true,
highlightWeek: true,
numberOfMonths: 1,
showAnim: "scale",
showOptions: {
Origin: ["top", "left"]
}
});
});
</script>
ここで2つのことを見逃しました:
DataFormatString="{0:dd/MM/yyyy}"; //It is dd/MM/yyyy instead of dd/mm/yyyy
また、次のものも必要です。
ApplyFormatInEditMode=true
これを使用してみてください:
[Display(Name = "Release Date")]
[DataType(DataType.Date), DisplayFormat( DataFormatString="{0:dd/MM/yyyy}", ApplyFormatInEditMode=true )]
public Nullable<DateTime> release_date { get; set; }
{0:dd/mm/yyyy}
は{0:dd/MM/yyyy}
mm
は月ではなく分を意味するため:
[Display(Name = "Release Date")]
[DataType(DataType.DateTime)]
[DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:dd/MM/yyyy}")]
public Nullable<DateTime> release_date { get; set; }
データ注釈を使用する場合。それを表示するとき。ただし、編集モードの場合。サーバー形式(カルチャ設定)を引き続き使用しますDisplayFormat:名前と同様、表示専用
解決するいくつかのオプションがあります。 -好きな形式で文字列としてサーバーに貼り付けます-顧客のバインドを記述します-web.configでフォーマットのグローバリゼーションを設定します。
<system.web>
<globalization culture="en-GB"/>
....