問題:MVC中使用控制器返回JsonResult,如果帶有日期字段的對象,瀏覽器接收到的json中會變成形如/Date('123123123')/格式。如何在easyui等中直接使用是個麻煩事。
解決方法:從源頭開始。既然Controller控制器的Json()方法會自動轉化,那我們就給它擴展一下,把格式化日期的功能替換成我們自己寫的格式:
首先,我們繼承JsonResult寫一個類,重載他的ExcuteResult:
/// <summary> /// 提供自定義日期格式 Json /// </summary> public class CustomJsonResult : JsonResult { public override void ExecuteResult(ControllerContext context) { if (context == null) { throw new ArgumentNullException("context"); } HttpResponseBase response = context.HttpContext.Response; if (Data != null) { var timeConverter = new IsoDateTimeConverter {DateTimeFormat = "yyyy-MM-dd HH:mm:ss"};//這里使用自定義日期格式,默認是ISO8601格式 response.Write(JsonConvert.SerializeObject(Data,Formatting.Indented,timeConverter)); } } }
然后,繼承Controller,實現一個BaseController
/// <summary> /// 本項目所有控制器的基類,提供Json方法,用來自定義格式化日期 /// </summary>public class BaseController : Controller { protected override JsonResult Json(object data, string contentType, Encoding contentEncoding) { return new CustomJsonResult {Data = data, ContentType = contentType, ContentEncoding = contentEncoding}; } public new JsonResult Json(object data, JsonRequestBehavior jsonRequest) { return new CustomJsonResult {Data = data, JsonRequestBehavior = jsonRequest}; } public new JsonResult Json(object data) { return new CustomJsonResult {Data = data, JsonRequestBehavior = JsonRequestBehavior.AllowGet}; } }
使用時,首先保證你的控制器是繼承自BaseController,而不是Controller,舉個栗子:
public JsonResult UserSrc() { var q = from u in db.T_User.Where(p=>!p.DelFlag) select new { UserID = u.UserID, UserName = u.UserName, RealName = u.RealName, Date=u.Date
}; return Json(q); }