最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 前端学习之编程题系列:(八)时间格式化输出

    正文概述 掘金(Crystal_Wei)   2021-02-12   532

    写在前面

    本题目来自牛客网,已经成功通过测试。笔者刚刚开始学习前端,准备在掘金记录下自己的学习过程,欢迎和我一样准备入门前端的小伙伴们一起交流学习,也欢迎各位大佬批评指正~~~

    题目描述

    按所给的时间格式输出指定的时间
    格式说明
    对于 2014.09.05 13:14:20
    yyyy: 年份,2014
    yy: 年份,14
    MM: 月份,补满两位,09
    M: 月份, 9
    dd: 日期,补满两位,05
    d: 日期, 5
    HH: 24制小时,补满两位,13
    H: 24制小时,13
    hh: 12制小时,补满两位,01
    h: 12制小时,1
    mm: 分钟,补满两位,14
    m: 分钟,14
    ss: 秒,补满两位,20
    s: 秒,20
    w: 星期,为 ['日', '一', '二', '三', '四', '五', '六'] 中的某一个,本 demo 结果为 五

    示例

    输入

    formatDate(new Date(1409894060000), 'yyyy-MM-dd HH:mm:ss 星期w')
    

    输出

    2014-09-05 13:14:20 星期五
    

    题解一

    function formatDate(oneDate, formatStr){
        const obj = {
            yyyy: oneDate.getFullYear(),
            yy: ("" + oneDate.getFullYear()).slice(-2),
            MM: ("0" + (oneDate.getMonth()+1)).slice(-2),
            M: oneDate.getMonth()+1,
            dd: ("0" + oneDate.getDate()).slice(-2),
            d: oneDate.getDate(),
            HH: ("0" + oneDate.getHours()).slice(-2),
            H: oneDate.getHours(),
            hh: ("0" + (oneDate.getHours()%12)).slice(-2),
            h: oneDate.getHours()%12,
            mm: ("0" + oneDate.getMinutes()).slice(-2),
            m: oneDate.getMinutes(),
            ss: ("0" + oneDate.getSeconds()).slice(-2),
            s: oneDate.getSeconds(),
            w: ['日', '一', '二', '三', '四', '五', '六'][oneDate.getDay()]
        }
        for (let el in obj){
            formatStr = formatStr.replace(el, obj[el])
        }
        return formatStr
    }
    

    题解二

    function formatDate(t,str){
      var obj = {
        yyyyyyyy:t.getFullYear(),
        yy:t.getFullYear(),
        MM:t.getMonth()+1,
        dd:t.getDate(),
        HH:t.getHours(),
        hh:t.getHours() % 12,
        mm:t.getMinutes(),
        ss:t.getSeconds(),
        ww:['日', '一', '二', '三', '四', '五', '六'][t.getDay()]
      };
      return str.replace(/([a-z]+)/ig,function($1){
          //$1是yyyy的时候yyyyyyyy有效,不会进入补零操作,w同理
          return (obj[$1+$1]===0?'0':obj[$1+$1])||('0'+obj[$1]).slice(-2);
      });
    }
    

    知识点

    1. Date() 对象及相关方法
    2. replace() 方法
    3. 正则表达式 $1
    4. slice() 方法

    起源地下载网 » 前端学习之编程题系列:(八)时间格式化输出

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元