/* eslint no-param-reassign: 0 */
/* eslint no-control-regex: 0 */
/* eslint no-restricted-syntax: 0 */
/* eslint no-prototype-builtins: 0 */
/* eslint no-continue: 0 */
export function parseTime(time, cFormat) {
if (arguments.length === 0) {
return null;
}
const format = cFormat || '{y}-{m}-{d} {h}:{i}:{s}';
let date;
if (typeof time === 'object') {
date = time;
} else {
if ((`${time}`).length === 10) time = parseInt(time, 10) * 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 timeStr = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => {
let value = formatObj[key];
if (key === 'a') return ['一', '二', '三', '四', '五', '六', '日'][value - 1];
if (result.length > 0 && value < 10) {
value = `0${value}`;
}
return value || 0;
});
return timeStr;
}
export function formatTime(time, option) {
time = +time * 1000;
const d = new Date(time);
const now = Date.now();
const diff = (now - d) / 1000;
if (diff < 30) {
return '刚刚';
} else if (diff < 3600) { // less 1 hour
return `${Math.ceil(diff / 60)}分钟前`;
} else if (diff < 3600 * 24) {
return `${Math.ceil(diff / 3600)}小时前`;
} else if (diff < 3600 * 24 * 2) {
return '1天前';
}
if (option) {
return parseTime(time, option);
}
return `${d.getMonth() + 1}月${d.getDate()}日${d.getHours()}时${d.getMinutes()}分`;
}
去除首尾空格、首字母大写、 格式化url参数等方法
最新推荐文章于 2022-09-21 14:54:16 发布
本文介绍了几种常见的字符串处理方法,包括去除字符串首尾空格、实现首字母大写以及如何正确格式化URL参数,这些都是在编程中经常会用到的操作。
摘要由CSDN通过智能技术生成