分享一个工具方法:日期格式化 & 日期转化,用法与java类SimpleDateFormat类似

这个博客主要介绍了JavaScript中用于日期格式化和字符串转日期对象的方法。`dateFormat`函数接收日期对象和格式字符串,返回格式化的日期字符串,如'yyyy-MM-dd HH:mm:ss'。而`parseDate`函数则将给定格式的日期字符串转换为Date对象,用于日期处理。这两个函数在处理日期显示和输入时非常实用。
摘要由CSDN通过智能技术生成
/**
 * y    年(201X)
 * M    年中的月份(1-12)
 * d    月份中的天数(1-31)
 * H    一天中的小时数(0-23)
 * h    am/pm 中的小时数(1-12)
 * m    小时中的分钟数(0-59)
 * s    分钟中的秒数(0-59)
 * S    毫秒数(0-999)
 */
/**
 * 格式化输出日期
 * eq: dateFormat(new Date(),"yyyy-MM-dd HH:mm:ss")
 */
export const dateFormat = (date,format) => {
    let reg = /[yMdHhmsS]/;
    let formatArr = format.match(/(.)\1*/g);
    let formatObj = {
        y:""+date.getFullYear(),
        M:"0"+(date.getMonth()+1),
        d:"0"+date.getDate(),
        H:"0"+date.getHours(),
        h:"0"+(date.getHours()>12?date.getHours()-12:(date.getHours()==0?12:date.getHours())),
        m:"0"+date.getMinutes(),
        s:"0"+date.getSeconds(),
        S:"00"+date.getMilliseconds()
    };
    let str = "";
    for(let i= 0,len = formatArr.length;i<len;i++){
        if(formatArr[i]){
            let char0 = formatArr[i].charAt(0);
            if(reg.test(char0)){
                let charLen = formatArr[i].length;
                str += formatObj[char0].slice(charLen*-1);
            }else{
                str += formatArr[i];
            }
        }
    }
    return str;
},
/**
 * 字符串转化为Date对象
 * eq: parseDate("yyyy-MM-dd HH:mm:ss","2017-10-24 20:33:11")
 */
export const parseDate = (dateStr,format) => {
    if(dateStr.length!==format.length){
        console.warn("parseDate: the length of the dateString and format is not equal");
    }
    let reg = /[yMdHhmsS]/;
    let formatArr = format.match(/(.)\1*/g);
    let date = new Date();
    let formatObj = {
        y:date.setFullYear,
        M:date.setMonth,
        d:date.setDate,
        H:date.setHours,
        h:date.setHours,
        m:date.setMinutes,
        s:date.setSeconds,
        S:date.setMilliseconds
    };
    for(let i = 0,formatLenCount = 0,len = formatArr.length;i<len;i++){
        let formatUnit = formatArr[i];
        if(formatUnit){
            let char0 = formatUnit.charAt(0);
            if(reg.test(char0)){
                let dateUnit = dateStr.substring(formatLenCount,formatLenCount+formatUnit.length);
                char0==="M"?formatObj[char0].call(date,dateUnit-1):formatObj[char0].call(date,dateUnit);
            }
        }
        formatLenCount += formatUnit.length;
    }
    return date;
},
/**

 * y    年(201X)

 * M    年中的月份(1-12)

 * d    月份中的天数(1-31)

 * H    一天中的小时数(0-23)

 * h    am/pm 中的小时数(1-12)

 * m    小时中的分钟数(0-59)

 * s    分钟中的秒数(0-59)

 * S    毫秒数(0-999)

 */

/**

 * 格式化输出日期

 * eq: dateFormat(new Date(),"yyyy-MM-dd HH:mm:ss")

 */

export const dateFormat = (date,format) => {

    let reg = /[yMdHhmsS]/;

    let formatArr = format.match(/(.)\1*/g);

    let formatObj = {

        y:""+date.getFullYear(),

        M:"0"+(date.getMonth()+1),

        d:"0"+date.getDate(),

        H:"0"+date.getHours(),

        h:"0"+(date.getHours()>12?date.getHours()-12:(date.getHours()==0?12:date.getHours())),

        m:"0"+date.getMinutes(),

        s:"0"+date.getSeconds(),

        S:"00"+date.getMilliseconds()

    };

    let str = "";

    for(let i= 0,len = formatArr.length;i<len;i++){

        if(formatArr[i]){

            let char0 = formatArr[i].charAt(0);

            if(reg.test(char0)){

                let charLen = formatArr[i].length;

                str += formatObj[char0].slice(charLen*-1);

            }else{

                str += formatArr[i];

            }

        }

    }

    return str;

},

/**

 * 字符串转化为Date对象

 * eq: parseDate("yyyy-MM-dd HH:mm:ss","2017-10-24 20:33:11")

 */

export const parseDate = (dateStr,format) => {

    if(dateStr.length!==format.length){

        console.warn("parseDate: the length of the dateString and format is not equal");

    }

    let reg = /[yMdHhmsS]/;

    let formatArr = format.match(/(.)\1*/g);

    let date = new Date();

    let formatObj = {

        y:date.setFullYear,

        M:date.setMonth,

        d:date.setDate,

        H:date.setHours,

        h:date.setHours,

        m:date.setMinutes,

        s:date.setSeconds,

        S:date.setMilliseconds

    };

    for(let i = 0,formatLenCount = 0,len = formatArr.length;i<len;i++){

        let formatUnit = formatArr[i];

        if(formatUnit){

            let char0 = formatUnit.charAt(0);

            if(reg.test(char0)){

                let dateUnit = dateStr.substring(formatLenCount,formatLenCount+formatUnit.length);// 可以得到 2017 | 10

                char0==="M"?formatObj[char0].call(date,dateUnit-1):formatObj[char0].call(date,dateUnit);

            }

        }

        formatLenCount += formatUnit.length;

    }

    return date;

},

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

短暂又灿烂的

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值