MVC4 DataType.Date EditorForに返信すると、Chromeでは日付値が表示されず、IEでは問題ありません
モデルでは、次のタイプの宣言が必要です。
[DataType(DataType.Date)]
public DateTime? DateXYZ { get; set; }
または
[DataType(DataType.Date)]
public Nullable<System.DateTime> DateXYZ { get; set; }
次の属性を使用する必要はありません。
[DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode = true)]
Date.cshtmlで次のテンプレートを使用します。
@model Nullable<DateTime>
@using System.Globalization;
@{
DateTime dt = DateTime.Now;
if (Model != null)
{
dt = (System.DateTime)Model;
}
if (Request.Browser.Type.ToUpper().Contains("IE") || Request.Browser.Type.Contains("InternetExplorer"))
{
@Html.TextBox("", String.Format("{0:d}", dt.ToShortDateString()), new { @class = "datefield", type = "date" })
}
else
{
//Tested in chrome
DateTimeFormatInfo dtfi = CultureInfo.CreateSpecificCulture("en-US").DateTimeFormat;
dtfi.DateSeparator = "-";
dtfi.ShortDatePattern = @"yyyy/MM/dd";
@Html.TextBox("", String.Format("{0:d}", dt.ToString("d", dtfi)), new { @class = "datefield", type = "date" })
}
}
楽しんで!よろしく、ブラートン