zoukankan      html  css  js  c++  java
  • 解决MVC返回Json中日期格式问题

    问题: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); }
    欢迎转载,但请保留链接 http://www.cnblogs.com/limlee --- GeekLion
  • 相关阅读:
    20190919-4 单元测试,结对
    20190919-3 效能分析
    20190919-2 功能测试
    git 和conding.net 超详细超简单安装
    html元素contenteditable属性如何定位光标和设置光标
    【分享】WeX5的正确打开方式(6)——数据组件初探
    从零开始开发一款H5小游戏(二) 创造游戏世界,启动发条
    分享一个自己写的基于canvas的原生js图片爆炸插件
    基于 HTML5 的 WebGL 技术构建 3D 场景(一)
    从零开始开发一款H5小游戏(三) 攻守阵营,赋予粒子新的生命
  • 原文地址:https://www.cnblogs.com/limlee/p/3094258.html
Copyright © 2011-2022 走看看