vue时间处理工具momentjs

摘要:自己写的时间处理工具类有兼容性, 网上找都处理很多可靠的很少,几个项目被坑惨了,有时候还要经常处理获取月份啊周啊什么的bug 实在多,自己写实在麻烦还考虑不全

为什么要用?

自己写的时间处理工具类有兼容性, 网上找都处理很多可靠的很少,几个项目被坑惨了


以前用的

 formatDate(timestamp, fmt = 'yyyy-MM-dd hh:mm:ss') {
    if (!timestamp) return null;
    let date = null;
    if (timestamp instanceof Date) {
      date = timestamp;
    } else {
      // 兼容
      date = new Date(timestamp.replace(new RegExp(/-/gm), '/'));
    }
    const o = {
      'y+': date.getFullYear(),
      'M+': date.getMonth() + 1,
      'd+': date.getDate(),
      'h+': date.getHours(),
      'm+': date.getMinutes(),
      's+': date.getSeconds(),
      'w+': date.getDay(),
    };
    Object.entries(o).forEach(([rxp, value]) => {
      fmt = fmt.replace(new RegExp(rxp), ($1) => {
        const str = `0000${value}`;
        if ($1 === 'M' || $1 === 'd') {
          if (value > 9) {
            return value;
          }
        } else if ($1 === 'ww') {
          const week = '一二三四五六日'.substr(value - 1, 1);
          return `周${week}`;
        }
        return str.substr(str.length - $1.length);
      });
    });
    return fmt;
  },

有时候还要经常处理获取月份啊周啊什么的bug 实在多,自己写实在麻烦还考虑不全,还有兼容性,崩溃...下面用moment来处理时间常用方式


format

moment().format();                                // "2014-09-08T08:02:17-05:00" (ISO 8601,无小数秒钟)
moment().format("dddd, MMMM Do YYYY, h:mm:ss a"); // "Sunday, February 14th 2010, 3:25:50 pm"
moment().format("ddd, hA");                       // "Sun, 3PM"
moment('gibberish').format('YYYY-MM-DD');         // "Invalid date"

格式

说明令牌输出|
月份M1 2 ... 11 12
Mo1st 2nd ... 11th 12th
MM 01 02 ... 11 12
MMM Jan Feb ... Nov Dec
MMMM January February ... November December
季度Q1 2 3 4
Qo1st 2nd 3rd 4th
月份的日期D1 2 ... 30 31
Do1st 2nd ... 30th 31st
DD01 02 ... 30 31
年份的日期DDD1 2 ... 364 365
DDDo1st 2nd ... 364th 365th
DDDD001 002 ... 364 365
星期几d0 1 ... 5 6
do0th 1st ... 5th 6th
ddSu Mo ... Fr Sa
dddSun Mon ... Fri Sat
ddddSunday Monday ... Friday Saturday
星期几(语言环境)e0 1 ... 5 6
星期几(ISO)E1 2 ... 6 7
年份的星期w1 2 ... 52 53
wo
ww01 02 ... 52 53
年份的星期(ISO)W1 2 ... 52 53
Wo1st 2nd ... 52nd 53rd
WW01 02 ... 52 53
Unix时间戳 X 1360013296
Unix毫秒时间戳 x 1360013296123

还有挺多具体请参考中文文档


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_8498