时间戳转时间格式(2018-07-25)

/**
 * exaple
 * var str = 'abcd';
 * 'yyyy-MM-dd hh:mm:ss'.replace('yyyy',str+'').substr(0)  => "abcd-MM-dd hh:mm:ss"
 * @param {new Date(time);} date
 * @param {yyyy-MM-dd hh:mm} fmt 
 */

export function formatDate(date, fmt) {
    if (/(y+)/.test(fmt)) {
        //RegExp.$1 正则表达式匹配的第一个内容   +''可将类型转化为字符串
        fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length));
    }
    let o = {
        'M+': date.getMonth() + 1,
        'd+': date.getDate(),
        'h+': date.getHours(),
        'm+': date.getMinutes(),
        's+': date.getSeconds()
    };
    for (let k in o) {
        if (new RegExp(`(${k})`).test(fmt)) { //`(${k})` => M+、d+、h+
            let str = o[k] + '';
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : padLeftZero(str)); //fmt=2016-07-dd hh:mm; RegExp.$1= MM; 
        }
    }
    return fmt;
};

function padLeftZero(str) {
    return ('00' + str).substr(str.length);
}

用法:let date = new Date(time);
           formatDate(date, 'yyyy-MM-dd hh:mm')

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 印尼语: 1.hh:mm 英语:06:05 印尼语:6:05 注:印尼使用24小时制所以应为H:mm 2.yyyy...
    黑炭妈阅读 13,319评论 3 4
  • pyspark.sql模块 模块上下文 Spark SQL和DataFrames的重要类: pyspark.sql...
    mpro阅读 9,547评论 0 13
  • ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02 13:45:25为例) Year:...
    雨一流阅读 694评论 0 2
  • 1 有个正在读大三的姑娘留言说,最近因为找实习的事情很苦恼。 一是觉得简历的含金量不够,不足以打动HR;二是担心在...
    Miss柳阅读 860评论 4 7
  • Hibernate框架第二天 课程回顾:Hibernate框架的第一天 今天内容 Hibernate的持久化类 什...
    yuxiaohu阅读 238评论 0 0