优秀js库moment
介绍
在工作场景中,我们经常需要处理时间格式,尤其在写 h5 时,需要考虑到 ios 和 安卓 兼容性( ios 不支持 yyyy-MM-dd 格式),以往我们的解决方式是自定义一个 formatDate 方法,现在有了 moment ,更方便了
以往的解决方式
class Type {
constructor (value) {
this.typeList = ['Null', 'Undefined', 'Object', 'Array', 'String', 'Number', 'Boolean', 'Function', 'RegExp', 'Date']
this.init()
}
type (value) {
let s = Object.prototype.toString.call(value)
return s.match(/\[object (.*?)\]/)[1].toLowerCase()
}
// 增加判断类型数据方法
init () {
this.typeList.forEach((t) => {
this['is' + t] = (o) => {
return this.type(o) === t.toLowerCase()
}
})
}
}
let type = new Type()
function formatDate (dateIn, fmt) {
if (!fmt) return false
let newDate = type['isDate'](dateIn) ? dateIn : new Date(dateIn)
let o = {
'y+': newDate.getFullYear(), // 年份
'M+': addZero(newDate.getMonth() + 1), // 月份
'd+': addZero(newDate.getDate()), // 某一天
'h+': addZero(newDate.getHours()), // 小时
'm+': addZero(newDate.getMinutes()), // 分钟
's+': addZero(newDate.getSeconds()) // 秒
}
for (let i in o) {
if (new RegExp('(' + i + ')').test(fmt)) {
fmt = fmt.replace(RegExp.$1, o[i])
}
}
return fmt
}
function addZero (e) {
return Number(e) < 10 ? `0${e}` : e
}moment常用方法
引入 moment 并初始化
时间字符串格式化
格式化令牌
年份、月份、日期的令牌
输入示例描述YYYY
2014
4 或 2 位数字的年份
YY
14
2 位数字的年份
Y
-25
带有任意数字和符号的年份
Q
1..4
年份的季度。将月份设置为季度的第一个月
M MM
1..12
月份数字
MMM MMMM
Jan..December
语言环境中的月份名称,由 moment.locale() 设置
D DD
1..31
月的某天
Do
1st..31st
月的某天,带序数
DDD DDDD
1..365
年的某天
X
1410715640.579
Unix 时间戳
x
1410715640579
Unix 毫秒时间戳
周年、星期、工作日的令牌
输入示例描述gggg
2014
语言环境的 4 位数字的周年
gg
14
语言环境的 2 位数字的周年
w ww
1..53
语言环境的年的第几周
e
0..6
语言环境的星期几
ddd dddd
Mon...Sunday
语言环境的星期几的名称,由 moment.locale() 设置
GGGG
2014
ISO 的 4 位数字的周年
GG
14
ISO 的 2 位数字的周年
W WW
1..53
ISO 的年的第几周
E
1..7
ISO 的星期几
小时、分钟、秒钟、毫秒、偏移量的令牌
输入示例描述H HH
0..23
小时(24 小时制)
h hh
1..12
小时(使用 a A 的 12 小时制)
k kk
1..24
小时(从 1 到 24 的 24 小时制)
a A
am pm
上午或下午(单一字符 a p 也被视为有效)
m mm
0..59
分钟
s ss
0..59
秒钟
S SS SSS
0..999
带分钟的秒钟
Z ZZ
+12:00
从 UTC 偏移为 +-HH:mm、+-HHmm 或 Z
格式试探
moment(Number)unix()moment(Date)moment(Number[])克隆
参考
Last updated
Was this helpful?