You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
5.5 KiB
188 lines
5.5 KiB
/**
|
|
* 日期时间处理的工具库
|
|
*
|
|
* @author lautin
|
|
* @created 2019-11-19 11:36:02
|
|
*/
|
|
function getTimeZoneOffset(time) {
|
|
const date = new Date(time);
|
|
// 获取时区偏移值,返回分钟数
|
|
// let offset = date.getTimezoneOffset();
|
|
let offset = 0;
|
|
return time + offset * 60 * 1000;
|
|
}
|
|
|
|
/**
|
|
* 将时间戳转化成时间对象的方法
|
|
* @param {mixed} time 传入一个时间戳或者时间对象
|
|
*/
|
|
function time2Date(time, isOffset = false) {
|
|
|
|
let date;
|
|
|
|
if (time.constructor == Date) { // 传入一个时间对象
|
|
date = time;
|
|
|
|
} else { // 传入一个时间戳
|
|
// 检测时间戳的长度,确保为ms
|
|
if (time.toString().length <= 10) {
|
|
time = Number(time) * 1000;
|
|
}
|
|
// 是否对时差进行转化
|
|
if (isOffset) {
|
|
// time = getTimeZoneOffset(time);
|
|
}
|
|
|
|
// 转化成日期时间对象
|
|
date = new Date(time);
|
|
}
|
|
|
|
return date;
|
|
}
|
|
|
|
|
|
/**
|
|
* 将指定日期格式化输出,
|
|
* @param string|object time 输入日期,为一个Date.now()或者Date.UTC返回的时间戳
|
|
* @param string format 输出的格式
|
|
* @param boolean isOffset 是否考虑时区
|
|
*/
|
|
function parseTime(time, isOffset = false, cformat = null) {
|
|
|
|
// 设置默认格式
|
|
// let format = cformat || '{y}-{m}-{d} {h}:{i}:{s}';
|
|
// time = time + 8 * 3600;
|
|
// const date = time2Date(time, isOffset);
|
|
|
|
// // 将日期时间值存入对象中
|
|
// const dataObj = {
|
|
// y: date.getFullYear(),
|
|
// m: date.getMonth() + 1, // 显示月份值需要+1
|
|
// d: date.getDate(),
|
|
// h: date.getHours(),
|
|
// i: date.getMinutes(),
|
|
// s: date.getSeconds(),
|
|
// a: date.getDay()
|
|
// };
|
|
// // console.log(date);
|
|
// // 星期值需要转化为中文
|
|
// dataObj.a = '星期' + ['日', '一', '二', '三', '四', '五', '六'][dataObj.a];
|
|
|
|
// // 匹配{}中的y|m|d...部分,分别替换不同的值
|
|
// // const result = format.replace(/{(y|m|d|h|i|s|a)+}/g, (segment, key) => {
|
|
// // // 由索引提取值
|
|
// // let value = dataObj[key];
|
|
// // // 给值添加前导0
|
|
// // if (segment.length > 0 && value < 10) value = '0' + value;
|
|
// // return value || 0;
|
|
// // });
|
|
// // time = time + 8 * 3600 * 1000; // 增加8小时
|
|
// const result = date.toJSON().substr(0, 19).replace('T', ' ');
|
|
// // console.log(result);
|
|
// return result;
|
|
|
|
|
|
// 设置默认格式
|
|
// let format = cformat || '{y}-{m}-{d} {h}:{i}:{s}';
|
|
let format = cformat || '{m}/{d}/{y} {h}:{i}:{s}';
|
|
|
|
const date = time2Date(time, isOffset);
|
|
|
|
// 将日期时间值存入对象中
|
|
const dataObj = {
|
|
y: date.getFullYear(),
|
|
m: date.getMonth() + 1, // 显示月份值需要+1
|
|
d: date.getDate(),
|
|
h: date.getHours(),
|
|
i: date.getMinutes(),
|
|
s: date.getSeconds(),
|
|
a: date.getDay()
|
|
};
|
|
|
|
// 星期值需要转化为中文
|
|
dataObj.a = '星期' + ['日', '一', '二', '三', '四', '五', '六'][dataObj.a];
|
|
|
|
// 匹配{}中的y|m|d...部分,分别替换不同的值
|
|
const result = format.replace(/{(y|m|d|h|i|s|a)+}/g, (segment, key) => {
|
|
// 由索引提取值
|
|
let value = dataObj[key];
|
|
// 给值添加前导0
|
|
if (segment.length > 0 && value < 10) value = '0' + value;
|
|
return value || 0;
|
|
});
|
|
return result;
|
|
}
|
|
|
|
/**
|
|
* 接口时间转换成12进制
|
|
* @param {string|number} dateTimeStr 接口返回的时间和日期
|
|
*/
|
|
function convertTo12HourFormat(dateTimeStr) {
|
|
// 解析输入的日期时间字符串
|
|
const date = new Date(dateTimeStr.replace(' ', 'T')); // 使用 T 将字符串转换为 ISO 格式
|
|
|
|
// 获取各个部分
|
|
const year = date.getFullYear();
|
|
const month = String(date.getMonth() + 1).padStart(2, '0'); // 月份要加1,并填充为2位
|
|
const day = String(date.getDate()).padStart(2, '0'); // 填充为2位
|
|
let hours = date.getHours();
|
|
const minutes = String(date.getMinutes()).padStart(2, '0'); // 填充为2位
|
|
const seconds = String(date.getSeconds()).padStart(2, '0'); // 填充为2位
|
|
|
|
// 计算12小时制的小时和 AM/PM
|
|
const ampm = hours >= 12 ? 'PM' : 'AM';//PM代表下午,AM代表上午。
|
|
// hours = String(hours % 12 || 12).padStart(2, '0'); // 0转换为12
|
|
|
|
// 格式化输出
|
|
// return `${day}-${month}-${year} ${hours}:${minutes}:${seconds} ${ampm}`;
|
|
return `${day}-${month}-${year}`;
|
|
}
|
|
|
|
|
|
/**
|
|
* 发布日期的特定显示方式,
|
|
* @param {string|number} time 显示日期的时间戳
|
|
* @param {string} option 可选参数显示日期
|
|
*/
|
|
function pubTime(time, isOffset = false, format = null) {
|
|
|
|
const date = time2Date(time, isOffset);
|
|
|
|
const current = isOffset ? getTimeZoneOffset(Date.now()) : Date.now();
|
|
|
|
// 计算时间的差值,返回s为单位的值
|
|
let diff = (current - date.valueOf()) / 1000;
|
|
|
|
// 2天以内显示距今时间
|
|
if (diff < 30) { // 30s-
|
|
return '刚刚';
|
|
|
|
} else if (diff < 3600) { // 1h-
|
|
return Math.ceil(diff / 60) + '分钟前';
|
|
|
|
} else if (diff < 3600 * 24) { // 1d-
|
|
return Math.ceil(diff / 3600) + '小时前';
|
|
|
|
} else if (diff < 3600 * 24 * 2) { // 2d-
|
|
return '1天前';
|
|
|
|
} else { // 超过2天显示发布日期
|
|
if (!format) format = '{y}年{m}月{d}日 {h}:{i}';
|
|
return parseTime(time, isOffset, format);
|
|
}
|
|
}
|
|
|
|
// 将方法写入构造函数 便于全局使用
|
|
Object.assign(Date, {
|
|
time2Date,
|
|
parseTime,
|
|
pubTime,
|
|
convertTo12HourFormat
|
|
});
|
|
|
|
export default{
|
|
time2Date,
|
|
parseTime,
|
|
pubTime,
|
|
convertTo12HourFormat
|
|
}
|
|
|