var dateHelper = new DateHelper();
console.log(dateHelper.getDateFormatString("YYYY-MM-dd"))
输出:2018-08-26 21:11:15
可以输入其他的分隔符
YYYY/MM/dd HH:mm:ss 2018/08/26 21:12:22
YY/MM/dd HH:mm 2018/08/26 21:14
dd/MM/YY HH:mm 26/08/2018 21:15
日常开发中难免会遇到这个需求,以前想用逻辑写一个,发现太麻烦。
以Y、H、M、D为例,不确定用户输入的顺序,关键词的个数,以及以什么分割。
再又、又一轮的正则表达式学习后(说多了都是泪),我觉得自己有点入门了,再次遇到相同的情况,也有了思路。
规则如下(跟Java语言中simpledateformat的规律是一样的,这里是其中的一部分):
y 年
M 月
d 日
H 时 在一天中 (0~23)
m 分
s 秒
代码如下
class DateHelper{
getElements(allString){
let date = new Date();
let obj = {
fullYear:date.getFullYear(),
year:date.getYear(),
date:date.getDate(),
hours:date.getHours(),
minutes:date.getMinutes(),
seconds:date.getSeconds(),
month:date.getMonth() + 1,
day:date.getDay(),
milliseconds:date.getMilliseconds(),
}
if(allString){
for(let key in obj){
obj[key] = obj[key] + "";
}
}
return obj;
}
getTimestamp(){
return +new Date();
}
getDateFormatString(format = 'YYYY-MM-dd'){
let perFormat = format;
let regexps = [/Y{1,4}/,/M{1,2}/,/d{1,2}/,/H{1,2}/,/m{1,2}/,/s{1,2}/];
let dateElements = this.getElements(true);
function addZero(origin,target){
if(origin.length == 2 && target.length == 1){
return "0"+target;
}
return target;
}
regexps.forEach((regexp,index)=>perFormat = perFormat.replace(regexp,function(all){
switch(index){
case 0:{
let val = dateElements.fullYear;
return val.substring(-all.length);
};break;
case 1:{
let val = dateElements.month;
return addZero(all,val);
};break;
case 2:{
let val = dateElements.date;
return addZero(all,val);
};break;
case 3:{
let val = dateElements.hours;
return addZero(all,val);
};break;
case 4:{
let val = dateElements.minutes;
return addZero(all,val);
};break;
case 5:{
let val = dateElements.seconds;
return addZero(all,val);
};break;
}
}))
return perFormat;
}
}
作为个人封装的js,满足实际需求就好,没必要一开始就做的大而全。