JS处理json日期格式化问题
2015-10-01 00:00
786 查看
起因
对于从C#返回的日期字段,当进行JSON序列化后,在前台JS里显示的并不是真正的日期,这让我们感觉很不爽,我们不可能为了这东西,把所有日期字段都变成string吧,所以,找了一个JS的扩展方法,来实现这个功能
实现
function ChangeDateFormat(jsondate) { jsondate = jsondate.replace("/Date(", "").replace(")/", ""); if (jsondate.indexOf("+") > 0) { jsondate = jsondate.substring(0, jsondate.indexOf("+")); } else if (jsondate.indexOf("-") > 0) { jsondate = jsondate.substring(0, jsondate.indexOf("-")); } var date = new Date(parseInt(jsondate, 10)); var month = date.getMonth() + 1 < 10 ? "0" + (date.getMonth() + 1) : date.getMonth() + 1; var currentDate = date.getDate() < 10 ? "0" + date.getDate() : date.getDate(); return date.getFullYear() + "年" + month + "月" + currentDate + "日" + " " + date.getHours() + ":" + date.getMinutes(); } //调用:ChangeDateFormat(data[i].arrDate)
调用
$.ajax({ type: "Get", textType: "json", url: "/UserInfo/GetUserWithdraw", data: { id: id }, success: function (data) { var result = html.replace(reg, function (node, key) { return { 'Money': data.Money, 'AddTime': ChangeDateFormat(data.AddTime), 'CashTime': data.CashTime }[key]; }); TsingdaTips.ask({ msg: result, show_btn: false, title: "提现申请详情" });//预计打款时间等于申请时音后的(5号或20号) } });
PS:返回的json时间如 /Date(1290371638000)/ 形式,怎样处理成 yyyy-MM-dd 这类格式
去掉/Date
直接格式化1290371638000
/** * 时间对象的格式化; */ Date.prototype.format = function(format){ /* * eg:format="YYYY-MM-dd hh:mm:ss"; */ var o = { "M+" : this.getMonth()+1, //month "d+" : this.getDate(), //day "h+" : this.getHours(), //hour "m+" : this.getMinutes(), //minute "s+" : this.getSeconds(), //second "q+" : Math.floor((this.getMonth()+3)/3), //quarter "S" : this.getMilliseconds() //millisecond } if(/(y+)/.test(format)) { format = format.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length)); } for(var k in o) { if(new RegExp("("+ k +")").test(format)) { format = format.replace(RegExp.$1, RegExp.$1.length==1 ? o[k] : ("00"+ o[k]).substr((""+ o[k]).length)); } } return format; }
使用方法:
var testDate = new Date(); var testStr = testDate.format("YYYY年MM月dd日hh小时mm分ss秒"); alert(testStr);
相关文章推荐
- 通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端的方法
- 谈谈JSON对象和字符串之间的相互转换JSON.stringify(obj)和JSON.parse(string)
- Ember.js 入门指南——异步路由
- JS原生Date类型方法
- js截断过长字符串为省略号算法
- JavaScript实现类的private、protected、public、static以及继承
- 菜鸟学JS(六)——JS在文本域光标位置插入文本
- js中的json处理
- javascript 学习备忘(三)
- js跨域访问的一个helloworld程序
- JS函数定义方式
- JavaScript高级程序设计之函数表达式之模仿块级作用域第7.3讲笔记
- Javascript高级程序设计第22章(高级技巧)
- JavaScript高级程序设计之函数表达式之闭包之内存泄漏第7.2.3讲笔记
- JavaScript高级程序设计之函数表达式之闭包之关于 this 对象第7.2.2讲笔记
- JavaScript高级程序设计之函数表达式之闭包之闭包与变量第7.2.1讲笔记
- 函数多层执行
- js学习注意知识
- js函数对象的总结
- JS生成随机的由字母数字组合的字符串