1、Date => String 代碼 /** * 函數描述:時間格式化工具 * @param format {String} 格式(y-年,M-月,d-日,H-時[24],h-時[12],m-分,s-秒,S-毫秒(3位數),q-季度,ap,午前am/午後pm) * @returns {String ...
1、Date => String
代碼
/**
* 函數描述:時間格式化工具
* @param format {String} 格式(y-年,M-月,d-日,H-時[24],h-時[12],m-分,s-秒,S-毫秒(3位數),q-季度,ap,午前am/午後pm)
* @returns {String}
*/
Date.prototype.format = function (format) {
var o = {
'M+': this.getMonth() + 1, // 月份
'd+': this.getDate(), // 日
'H+': this.getHours(), // 時(24小時制)
'h+': this.getHours() % 12 === 0 ? 12 : this.getHours() % 12, // 時(12小時制)
'm+': this.getMinutes(), // 分
's+': this.getSeconds(), // 秒
'q+': Math.floor((this.getMonth() + 3) / 3), // 季度
'S': this.getMilliseconds(), // 毫秒
'ap': this.getHours() > 12 ? 'am' : 'pm'
};
var week = ['日', '一', '二', '三', '四', '五', '六'];
if (/(y+)/.test(format)) {
format = format.replace(RegExp.$1, (this.getFullYear() + '').substr(4 - RegExp.$1.length));
}
if (/(E+)/.test(format)) {
format = format.replace(RegExp.$1, ((RegExp.$1.length > 1) ? (RegExp.$1.length > 2 ? '星期' : '周') : '') + week[this.getDay()]);
}
for (var k in o) {
if (new RegExp('(' + k + ')').test(format)) {
format = format.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)));
}
}
return format;
};
使用
let date = new Date();
let format1 = 'yyyy年MM月dd日 HH:mm:ss.S EEE 第q季度';
let format2 = 'yyyy年M月d日 h:m:s.S ap EE 第q季度';
let format3 = 'yyyy-MM-dd HH:mm:ss.S ap E';
console.log(format1 + " =>", date.format(format1));
console.log(format2 + " =>", date.format(format2));
console.log(format3 + " =>", date.format(format3));
運行結果:
D:\DevEnvironment\NodeJs\node.exe D:\MyProjects\coding-study\src\main\resources\static\utils.js
format1 => 2022年09月23日 23:24:39.836 星期五 第3季度
format2 => 2022年9月23日 11:24:39.836 am 周五 第3季度
format3 => 2022-09-23 23:24:39.836 am 五
Process finished with exit code 0
2、String => Date
代碼
/**
* @desc 時間工具對象
*/
const DateUtils = {
format1: 'yyyy-MM-dd HH:mm:ss',
format2: 'yyyy年MM月dd日 HH時mm分ss秒',
/**
* 方法描述:將字元串轉為時間對象
* @param time {String} 時間字元串
* @param format {String} 時間格式
* @returns {Date}
*/
convert(time, format) {
if (time instanceof Date) {
return time;
}
if (time && typeof time === 'string') {
let getValue = function (regex) {
let str = regex ? time.substr(regex.index, regex[0].length) : '';
return str ? parseInt(str) : undefined;
}
// 各個時間的值,未獲取到則取最小值
let times = [
getValue(/y+/.exec(format)) || 0, // 年
getValue(/M+/.exec(format)) || 0, // 月
getValue(/d+/.exec(format)) || 1, // 日
/H+/.test(format) ? getValue(/H+/.exec(format)) : ((/h+/.test(format) && /pm/i.test(format)) ? getValue(/h+/.exec(format)) + 12 : getValue(/h+/.exec(format))) || 0, // 時
getValue(/m+/.exec(format)) || 0, // 分
getValue(/s+/.exec(format)) || 0, // 秒
function () {
let reg, regArr;
reg = new RegExp(/(\d{1,3}).*/, 'g'); reg.lastIndex = format.indexOf("S");
return reg.lastIndex > -1 ? (regArr = reg.exec(time)) && parseInt(regArr[1]) : undefined;
} () || 0// 毫秒
];
times[1] && (times[1] -= 1);
return new Date(...times);
}
}
}
使用
let date = new Date();
let dateStr1 = date.format(DateUtils.format1);
let dateStr2 = date.format(DateUtils.format2);
console.log(dateStr1 + ' =>', DateUtils.convert(dateStr1, DateUtils.format1));
console.log(dateStr2 + ' =>', DateUtils.convert(dateStr2, DateUtils.format2));
運行結果:
D:\DevEnvironment\NodeJs\node.exe D:\MyProjects\coding-study\src\main\resources\static\utils.js
2022-09-23 23:38:08 => 2022-09-23T15:38:08.000Z
2022年09月23日 23時38分08秒 => 2022-09-23T15:38:08.000Z
Process finished with exit code 0