js实用方法 ------ 格式化时间日期对象、时间戳、时间字符串。 返回格式为:yyyy-MM-dd hh:mm:ss 或 yyyy/MM/dd

js实用方法 — 时间格式化

对于自己平时使用的常用的方法做一个记录。

不喜欢引入别的时间处理库,然后自己动手写成自己的方法。增肌获取日期的季度

具体代码如下
	/* 格式化时间日期对象、时间戳、时间字符串
	 ** dataTime为时间日期对象、时间戳、时间字符串三者之一
	 ** format为格式化的格式字符串
	 */
   function Format(dataTime, format) {
      if (!dataTime) return '';
      if (dataTime.constructor !== Date) { // 判断是否为 时间Date
        dataTime = new Date(dataTime); // date 类型数据转成 时间字符串
      }
      let o = {
        "M+": dataTime.getMonth() + 1,  // 月份
        "d+": dataTime.getDate(),       // 日
        "h+": dataTime.getHours(),      // 小时
        "m+": dataTime.getMinutes(),    // 分
        "s+": dataTime.getSeconds(),    // 秒
        "q+": Math.floor((dataTime.getMonth() + 3) / 3), // 季度
        S: dataTime.getMilliseconds(),  // 毫秒
      };
      if (/(y+)/.test(format)) {
        format = format.replace(
          RegExp.$1, // RegExp.$1是RegExp的一个属性,指的是与正则表达式匹配的第一个 子匹配(以括号为标志)字符串
          (dataTime.getFullYear() + "").substr(4 - RegExp.$1.length)
        );
      }
      for (const k in o) {
        if (new RegExp("(" + k + ")").test(format)) { // 对o 里面定义的数据进行匹配 赋值
          format = format.replace(
            RegExp.$1,
            RegExp.$1.length === 1
              ? o[k]
              : ("00" + o[k]).substr(("" + o[k]).length)
          );
        }
      }
      return format
    }
调用方式
// 时间戳
this.Format("1644917973815", "yyyy-MM-dd  hh:mm:ss ");     // 2022-02-15  17:32:59
this.Format("1644917973815", "yyyy/MM/dd  hh:mm:ss ");     // 2022/02/15  17:32:59
// date类型
this.Format("Tue Feb 15 2022 18:02:30 GMT+0800 (中国标准时间)", "yyyy-MM-dd  hh:mm:ss ");
// 2022-02-15 18:02:30
this.Format("Tue Feb 15 2022 18:02:30 GMT+0800 (中国标准时间)", "yyyy/MM/dd  hh:mm:ss ");
// 2022/02/15 18:02:30
// 时间字符串
this.Format("2022-02-15", "yyyy-MM-dd "); // 2022-02-15 
this.Format("2022-02-15", "yyyy/MM/dd "); // 2022/02/15 
  • 13
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值