Moment.js 轻量级时间工具库

Moment.js是一个轻量级的JavaScript时间库,它方便了日常开发中对时间的操作,提高了开发效率。

1.1. 获取时间

1.1.1. Start of Time

  • 语法 ``` moment().startOf(String)
  1. - 获取今天000

moment().startOf(‘day’)

  1. - 获取本周第一天(周日)000

moment().startOf(‘week’)

  1. - 获取本周周一000

moment().startOf(‘isoWeek’)

  1. - 获取当前月第一天000

moment().startOf(‘month’)

  1. #### 1.1.2. End of Time
  2. - 语法:

moment().endOf(String)

  1. - 获取今天235959

moment().endOf(‘day’)

  1. - 获取本周最后一天(周六)235959

moment().endOf(‘week’)

  1. - 获取本周周日235959

moment().endOf(‘isoWeek’)

  1. - 获取当前月最后一天235959

moment().endOf(‘month’)

  1. #### 1.1.3. Days in Month
  2. - 语法

moment().daysInMonth()

  1. - 获取当前月的总天数

moment().daysInMonth()

  1. #### 1.1.4. Timestamp
  2. - 获取时间戳(以秒为单位)

moment().format(‘X’) // 返回值为字符串类型 moment().unix() // 返回值为数值型

  1. - 获取时间戳(以毫秒为单位)

moment().format(‘x’) // 返回值为字符串类型 moment().valueOf() // 返回值为数值型

  1. #### 1.1.5. Get Time
  2. - 获取年份

moment().year() moment().get(‘year’)

  1. - 获取月份

moment().month() (0~11, 0: January, 11: December) moment().get(‘month’)

  1. - 获取一个月中的某一天

moment().date() moment().get(‘date’)

  1. - 获取一个星期中的某一天

moment().day() (0~6, 0: Sunday, 6: Saturday) moment().weekday() (0~6, 0: Sunday, 6: Saturday) moment().isoWeekday() (1~7, 1: Monday, 7: Sunday) moment().get(‘day’) mment().get(‘weekday’) moment().get(‘isoWeekday’)

  1. - 获取小时

moment().hours() moment().get(‘hours’)

  1. - 获取分钟

moment().minutes() moment().get(‘minutes’)

  1. - 获取秒数

moment().seconds() moment().get(‘seconds’)

  1. - 获取当前的年月日时分秒

moment().toArray() // [years, months, date, hours, minutes, seconds, milliseconds] moment().toObject() // {years: xxxx, months: x, date: xx …}

  1. ### 1.2. 设置时间
  2. #### 1.2.1. Set Time
  3. - 语法:

moment().year(Number), moment().month(Number)… moment().set(String, Int) moment().set(Object)

  1. - 设置年份

moment().year(2019) moment().set(‘year’, 2019) moment().set({year: 2019})

  1. - 设置月份

moment().month(11) // (0~11, 0: January, 11: December) moment().set(‘month’, 11)

  1. - 设置某个月中的某一天

moment().date(15) moment().set(‘date’, 15)

  1. - 设置某个星期中的某一天

moment().weekday(0) // 设置日期为本周第一天(周日) moment().isoWeekday(1) // 设置日期为本周周一 moment().set(‘weekday’, 0) moment().set(‘isoWeekday’, 1)

  1. - 设置小时

moment().hours(12) moment().set(‘hours’, 12)

  1. - 设置分钟

moment().minutes(30) moment().set(‘minutes’, 30)

  1. - 设置秒数

moment().seconds(30) moment().set(‘seconds’, 30)

  1. #### 1.2.2. Add Time
  2. - 语法:

moment().add(Number, String) moment().add(Object)

  1. - 设置年份

moment().add(1, ‘years’) moment().add({years: 1})

  1. - 设置月份

moment().add(1, ‘months’)

  1. - 设置日期

moment().add(1, ‘days’)

  1. - 设置星期

moment().add(1, ‘weeks’)

  1. - 设置小时

moment().add(1, ‘hours’)

  1. - 设置分钟

moment().add(1, ‘minutes’)

  1. - 设置秒数

moment().add(1, ‘seconds’)

  1. #### 1.2.3. Subtract Time
  2. - 语法:

moment().subtract(Number, String) moment().subtract(Object)

  1. - 设置年份

moment().subtract(1, ‘years’) moment().subtract({years: 1})

  1. - 设置月份

moment().subtract(1, ‘months’)

  1. - 设置日期

moment().subtract(1, ‘days’)

  1. - 设置星期

moment().subtract(1, ‘weeks’)

  1. - 设置小时

moment().subtract(1, ‘hours’)

  1. - 设置分钟

moment().subtract(1, ‘minutes’)

  1. - 设置秒数

moment().subtract(1, ‘seconds’)

  1. ### 1.3. 格式化时间
  2. #### 1.3.1. Format Time
  3. - 语法:

moment().format() moment().format(String)

  1. - 格式化年月日:'xxxx年xx月xx日'

moment().format(‘YYYY年MM月DD日’)

  1. - 格式化年月日:'xxxx-xx-xx'

moment().format(‘YYYY-MM-DD’)

  1. - 格式化时分秒(24小时制):'xx时xx分xx秒'

moment().format(‘HH时mm分ss秒’)

  1. - 格式化时分秒(12小时制):'xx:xx:xx am/pm'

moment().format(‘hh:mm:ss a’)

  1. - 格式化时间戳(以秒为单位)

moment().format(‘X’) // 返回值为字符串类型

  1. - 格式化时间戳(以毫秒为单位)

moment().format(‘x’) // 返回值为字符串类型

  1. ### 1.4. 比较时间
  2. #### 1.4.1. Difference
  3. ##### 1.4.1.1. 语法

moment().diff(Moment|String|Number|Date|Array)

  1. - 获取两个日期之间的时间差

let start_date = moment().subtract(1, ‘weeks’) let end_date = moment()

end_date.diff(start_date) // 返回毫秒数

end_date.diff(start_date, ‘months’) // 0 end_date.diff(start_date, ‘weeks’) // 1 end_date.diff(start_date, ‘days’) // 7 start_date.diff(end_date, ‘days’) // -7

  1. ##### 1.4.1.2. 案例

// 一:计算小时之间的差 const date1 = moment(‘08:30’, ‘hh:mm’); const date2 = moment(‘18:00’, ‘hh:mm’); const date3 = date2.diff(date1, ‘minute’); // 计算相差的分钟数 const h = Math.floor(date3 / 60); // 相差的小时数 const mm = date3 % 60; // 计算相差小时后余下的分钟数

// 二: 在标准日期格式下可以不指定日期的格式 const date1 = moment(‘2019-02-28 08:30:00’); const date2 = moment(‘2019-02-28 18:00:00’); const date3 = date2.diff(date1, ‘minute’); // 计算相差的分钟数 const h = Math.floor(date3 / 60); // 相差的小时数 const mm = date3 % 60; // 计算相差小时后余下的分钟数

  1. ### 1.5. 转化为JavaScript原生Date对象
  2. - 语法:

moment().toDate() new Date(moment())

  1. - Moment时间转换为JavaScript原生Date对象

let m = moment() let nativeDate1 = m.toDate() let nativeDate2 = new Date(m)

String(nativeDate1) === String(nativeDate2) // true

```

2. Moment.js的官网相关的格式的字符

格拭字符列表