JS实现日期的格式化输出

516 阅读1分钟

原文出自:www.hangge.com 原文链接:www.hangge.com/blog/cache/…

背景

有时我们需要在 javascript 中对日期进行格式化,将其转换成固定格式的字符串。网上有许多现成的 JS 日期库可以使用,其实不借助这些库我们也可以自己实现。

对Date进行扩展

为方便我们对日期(Date)进行格式化输出,先对 Date 进行扩展,增加 format 方法。以后调用 Date 对象的 format 方法即可将日期转换成我们指定格式的字符串(String)。

Date.prototype.format = function (fmt) {
  var o = {
      "M+": this.getMonth() + 1, //月份
      "d+": this.getDate(), //日
      "h+": this.getHours(), //小时
      "m+": this.getMinutes(), //分
      "s+": this.getSeconds(), //秒
      "q+": Math.floor((this.getMonth() + 3) / 3), //季度
      "S": this.getMilliseconds() //毫秒
  };
  if (/(y+)/.test(fmt)) {
    fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
  }
  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;
}

案例

1、格式化输出当前时间:

(new Date()).format("yyyy-MM-dd hh:mm:ss.S") // 2019-03-21 17:01:25.928
(new Date()).format("yyyy-M-d h:m:s.S")      // 2019-3-21 17:2:37.719

2、格式化输出指定时间:

var date = new Date("2019-03-31 15:40:16.0");
date.format("MM-dd hh:mm");  //03-31 15:40``

javascript 日期格式化学习:
原文出自:www.hangge.com 原文链接:www.hangge.com/blog/cache/…

欢迎进qq群交流:704028989