一、代码注释详解
参数相关
date为传入时间
例:"2023/5/10 11:32:01" 2023-02-01 09:32:01type为返回类型
例:YYYY-MM-DD YYYY年MM月DD日 X月前 参数字母统一为大写默认规则,大于一天(24小时)展示'X天前;如果大于等于30天,展示"X个月前"
zeroFillFlag参数
为是否数字补零,默认补零
传入时间为必写参数,type和zeroFillFlag参数可选填
时间处理公式依据
- 10秒: 10 * 1000
- 1分钟: 60 * 1000
- 1小时: 60 * 60 * 1000
- 24小时(一天):60 * 60 * 24 * 1000
typescript
const formatPast = (date, type = "X个月前", zeroFillFlag = true) => {
// 定义countTime变量,用于存储计算后的数据
let countTime;
// 获取当前时间戳
let time = new Date().getTime();
// 转换传入参数为时间戳
let afferentTime = new Date(date).getTime();
// 当前时间戳 - 传入时间戳
time = Number.parseInt(`${time - afferentTime}`);
if (time < 10000) {
// 10秒内
return "刚刚";
} else if (time < 60000 && time >= 10000) {
// 超过10秒少于1分钟内
countTime = Math.floor(time / 1000);
return `${countTime}秒前`;
} else if (time < 3600000 && time >= 60000) {
// 超过1分钟少于1小时
countTime = Math.floor(time / 60000);
return `${countTime}分钟前`;
} else if (time < 86400000 && time >= 3600000) {
// 超过1小时少于24小时
countTime = Math.floor(time / 3600000);
return `${countTime}小时前`;
} else if (time >= 86400000 && (type == "X天前" || type == "X个月前")) {
countTime = Math.floor(time / 86400000);
// 如果大于等于30天 且传入格式为"X个月前"
if (countTime >= 30 && type == "X个月前") {
return `${Math.floor(countTime / 30)}个月前`;
}
// 否则展示'X天前'
return `${countTime}天前`;
} else {
// 一天(24小时)以上 按传入格式参数显示不同格式
// 数字补零
let Y = new Date(date).getFullYear();
let M = new Date(date).getMonth() + 1;
let zeroFillM = M > 9 ? M : "0" + M;
let D = new Date(date).getDate();
let zeroFillD = D > 9 ? D : "0" + D;
if (type == "YYYY-MM-DD") {
return zeroFillFlag ? `${Y}-${zeroFillM}-${zeroFillD}` : `${Y}-${M}-${D}`;
} else if (type == "YYYY/MM/DD") {
return zeroFillFlag ? `${Y}/${zeroFillM}/${zeroFillD}` : `${Y}/${M}/${D}`;
}
if (type == "YYYY年MM月DD日") {
return zeroFillFlag
? `${Y}年${zeroFillM}月${zeroFillD}日`
: `${Y}年${M}月${D}日`;
}
if (type == "YYYY.MM.DD") {
return zeroFillFlag ? `${Y}.${zeroFillM}.${zeroFillD}` : `${Y}.${M}.${D}`;
}
if (type == "MM月DD日") {
return zeroFillFlag ? `${zeroFillM}月${zeroFillD}日` : `${M}月${D}日`;
}
}
};
console.log(formatPast("2023-11-11 11:11:11")); // 1个月前
console.log(formatPast("2023-02-01 09:32:01", "YYYY-MM-DD", false)); // 2023-2-1
console.log(formatPast("2023.12.8 19:32:01", "YYYY/MM/DD")); // 2023/12/08
console.log(formatPast("2023/5/10 11:32:01", "YYYY年MM月DD日")); // 2023年05月10日
console.log(formatPast("2023/6/25 11:32:01", "YYYY.MM.DD", false)); // 2023.6.25
console.log(formatPast("2023/8/08 11:32:01", "MM月DD日")); // 08月08日
console.log(formatPast("2023-07-10 21:32:01", "X天前")); // 171天前