js转换json格式时间成字符串前台显示

1.ajax请求后台,后台返回需要的数据,其中返回数据有json格式的时间类型,这样需要转换成字符串用来前台显示,数据如下:

{“upointInfo”:[{“createDate”:{“date”:16,”day”:3,”hours”:15,”minutes”:47,”month”:0,”nanos”:0,”seconds”:23,”time”:1358322443000,”timezoneOffset”:-480,”year”:113},”pntId”:0,”pointDate”:{“date”:3,”day”:4,”hours”:0,”minutes”:0,”month”:0,”nanos”:0,”seconds”:0,”time”:1357142400000,”timezoneOffset”:-480,”year”:113},”pointExpDate”:{“date”:31,”day”:2,”hours”:0,”minutes”:0,”month”:11,”nanos”:0,”seconds”:0,”time”:1388419200000,”timezoneOffset”:-480,”year”:113},”pointId”:1,”pointNum”:50,”pointOperTypeId”:1,”pointTypeId”:1,”productRegId”:”999”,”productSn”:”778”,”userId”:3376094},{“createDate”:{“date”:16,”day”:3,”hours”:15,”minutes”:47,”month”:0,”nanos”:0,”seconds”:59,”time”:1358322479000,”timezoneOffset”:-480,”year”:113},”pntId”:0,”pointDate”:{“date”:4,”day”:1,”hours”:0,”minutes”:0,”month”:0,”nanos”:0,”seconds”:0,”time”:32914137600000,”timezoneOffset”:-480,”year”:1113},”pointExpDate”:{“date”:31,”day”:2,”hours”:0,”minutes”:0,”month”:11,”nanos”:0,”seconds”:0,”time”:1388419200000,”timezoneOffset”:-480,”year”:113},”pointId”:2,”pointNum”:100,”pointOperTypeId”:2,”pointTypeId”:1,”productRegId”:”888”,”productSn”:”798”,”userId”:3376094}],”resultMsg”:”操作成功!”,”isSuccess”:true}

逻辑是读取json格式中time字段,time是一个long类型的时间串,拿它进行转换:

2.使用实例

formartDate("yyyy-MM-dd",upointInfo.createDate.time);
function formartDate(dataFormate, time) {
    var date = new Date();
    date.setTime(time);
    return date.pattern(dataFormate);
}
Date.prototype.pattern = function(fmt) {
    var o = {
        "M+" : this.getMonth() + 1, //月份     
        "d+" : this.getDate(), //日     
        "h+" : this.getHours() % 12 == 0 ? 12 : this.getHours() % 12, //小时     
        "H+" : this.getHours(), //小时     
        "m+" : this.getMinutes(), //分     
        "s+" : this.getSeconds(), //秒     
        "q+" : Math.floor((this.getMonth() + 3) / 3), //季度     
        "S" : this.getMilliseconds()
    //毫秒     
    };
    var week = {
        "0" : "日",
        "1" : "一",
        "2" : "二",
        "3" : "三",
        "4" : "四",
        "5" : "五",
        "6" : "六"
    };
    if (/(y+)/.test(fmt)) {
        fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "")
                .substr(4 - RegExp.$1.length));
    }
    if (/(E+)/.test(fmt)) {
        fmt = fmt.replace(RegExp.$1,
                ((RegExp.$1.length > 1) ? (RegExp.$1.length > 2 ? "星期" : "周")
                        : "")
                        + week[this.getDay() + ""]);
    }
    if (/(e+)/.test(fmt)) {
        fmt = fmt.replace(RegExp.$1,
                ((RegExp.$1.length > 1) ? (RegExp.$1.length > 2 ? "星期" : "周")
                        : "")
                        + this.getDay());
    }
    for ( var k in o) {
        if (new RegExp("(" + k + ")").test(fmt)) {
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k])
                    : (("00" + o[k]).substr(("" + o[k]).length)));
        }
    }
    return fmt;
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值