常用util.js
记录一下自己在 js 学习中常用到的一些方法,进行封装使用
1.时间格式解析
首当其冲的就是这个时间格式解析了,js 的 Date 中有一个方法toLocaleString()
返回的结果为本地时间,如new Date().toLocaleString()
返回为2020/10/21 上午1:03:17
,好像看着并没有什么问题,但是我如果要将2020/10/21 上午1:03:17
转为时间戳的话,也就是执行new Date("2020/10/21 上午5:03:17").getTime()
,然而它却返回NaN
,不合理啊,时间格式难道不是这样的吗,时间格式 还真不是这样,上面只是显示为本地的时间,然而对于 js 而言,它只识别yyyy-MM-dd HH:mm:ss
这样的时间格式。于是就需要对返回的时间格式进行操作了。
可以通过下方的解析函数,并带上对应的时间格式返回给我对应的时间,代码就不分析了,我也是借鉴网络上的一些格式化时间代码,修改而来的。
function parseTime(time, cFormat) {
if (arguments.length === 0 || !time) {
return null
}
const format = cFormat || '{y}-{m}-{d} {h}:{i}:{s}'
let date
if (typeof time === 'object') {
date = time
} else {
if (typeof time === 'string') {
if (/^[0-9]+$/.test(time)) {
time = parseInt(time)
} else {
time = time.replace(new RegExp(/-/gm), '/')
}
}
if (typeof time === 'number' && time.toString().length === 10) {
time = time * 1000
}
date = new Date(time)
}
const formatObj = {
y: date.getFullYear(),
m: date.getMonth() + 1,
d: date.getDate(),
h: date.getHours(),
i: date.getMinutes(),
s: date.getSeconds(),
a: date.getDay(),
}
const time_str = format.replace(/{([ymdhisa])+}/g, (result, key) => {
const value = formatObj[key]
if (key === 'a') {
return ['日', '一', '二', '三', '四', '五', '六'][value]
}
return value.toString().padStart(2, '0')
})
return time_str
}