Extjs4若何處置後台json數據中日期和時光。本站提示廣大學習愛好者:(Extjs4若何處置後台json數據中日期和時光)文章只能為提供參考,不一定能成為您想要的結果。以下是Extjs4若何處置後台json數據中日期和時光正文
當ASP.NET後台應用JavaScriptSerializer這個組件將對象序列化為json,或許應用ScriptMethod特征的json
[ScriptMethod(ResponseFormat = ResponseFormat.Json), WebMethod(EnableSession = true)] public List<EUser> Users()//參數測試用 { List<EUser> l = new List<EUser>(); Random aran = new Random(); for (int i = 0; i < 24; i++) { DateTime date = DateTime.Parse("2015-08-21"); date = date.AddHours(i); var u = new EUser(date,Math.Round(aran.NextDouble() * 100) , Math.Round(aran.NextDouble() * 100), Math.Round(aran.NextDouble() * 100)); l.Add(u); } return l; }
生成的日期json格局是如許的//Date(1213718400000+0800)//
這類格局ExtJs不辨認,招致Grid上沒法正常顯示。應用ExtJS4的時刻,在列形式裡像上面如許處置便可。
{ text:'審核時光', dataIndex:'Date', width:200, renderer: function(value) { if(value){ var dt=eval("new " + value.substr(1, value.length - 2)).toString(); return Ext.util.Format.date(dt, "Y年m月d日H時i分s秒");//"Y年m月d日H時i分s秒" } } }
當ASP.NET後台應用Newtonsoft.Json(JSON.NET)這個組件將對象序列化為json,
Hashtable ht = new Hashtable(); ht.Add("total", listu.Count); ht.Add("rows", listu); JsonStr = JsonConvert.SerializeObject(ht);//應用json.net序列化 context.Response.Write(JsonStr);
生成的日期格局是尺度的日期像如許子:
"2013-01-15T15:00:00"
{ text:'審核時光', dataIndex:'Date', width:200, xtype:'datecolumn', format:'Y年m月d日H時i分s秒' }
Extjs4---json處置日期的成績 JSONObject.toBean轉換日期時顯示以後日期
明天碰著了一個新成績,在前台修正日期後,在後台用JSONObject.toBean轉為實體類時出成績了:
1、會顯示正告:Can't transform property 'birthday' from java.lang.String into java.util.Date. Will register a default Morpher
2、轉換的日期為以後的日期,而不是修正後的日期
緣由是JSONObject不克不及辨認相似“yyyy-MM-dd”的格局
處理的方法有許多,上面分享我用的一種辦法:
JSONObject object = JSONObject.fromObject(updateUser); //在<span >JSONObject.toBean加上這行代碼便可以了</span> JSONUtils.getMorpherRegistry().registerMorpher(new DateMorpher(new String[] {"yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss"})); User user = (User) JSONObject.toBean(object, User.class);
經由過程此辦法成績處理,辦法還有許多種,迎接年夜家分享,功效進修提高。