用正则表达式做日期格式化

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,满足实际需求就好,没必要一开始就做的大而全。

你可能感兴趣的:(用正则表达式做日期格式化)