一个方便的日期格式器

Posted Claiyre

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一个方便的日期格式器相关的知识,希望对你有一定的参考价值。

javascript的Date类型只能直接输出特定的形式的表示时间的字符,如:Tue Sep 20 2016 21:37:06 GMT+0800

但我们很少需要输出这样格式的时间

本文后面的代码,通过调用$.formatDate()函数,即可输出你想要的格式的时间

如:

var now=new Date();
document。write($.formatDate(now,"M/d/yyyy HH:mm"));

即可输出  9/20/2016 21:37

document.write($.formatDate(now,"M/d/yy HH:mm"));
document.write($.formatDate(now,"MM/d/yyyy HH:mm"));
document.write($.formatDate(now,"EEE MMM, d yyyy hh:mm:ss.S a"));

分别输出 9/20/16 21:43          09/20/2016 21:43

             Wed Sep, 21 2016 07:22:28.767 PM

其中,yyyy代表4位数字的年份,yy代表两位数字的年份;

        MMMM代表完整的英文月份名称,MMM代表月份英文名称的缩写,MM代表由0补足的两位数字的月份,M代表月份数字

       dd---由0补足的两位数字的月份中的天,d---月份中的天的缩写

       EEEE---星期的英文完整名称,EEE---星期的英文名称的缩写

       a---上午或下午

       HH---由0补足的,2位数字的2,24小时制的第几小时,H---一天中的第几小时,hh---由0补足的,2位数字的12小时制中的第几小时,h---12小时制的第几小时

       mm---由0补足的,2位数字的分钟数,m---一小时中的分钟数

       ss---由0补足的,2位数字的分钟数,s---一分钟内的秒数,S由0补足的,一秒内的毫秒数

 

     好啦,快收藏下面的代码愉快地使用Date吧!

 

(function($){
  $.formatDate = function(date,pattern) {
    var result = [];
    while (pattern.length>0) {
      $.formatDate.patternParts.lastIndex = 0;
      var matched = $.formatDate.patternParts.exec(pattern);
      if (matched) {
        result.push($.formatDate.patternValue[matched[0]].call(this,date));
        pattern = pattern.slice(matched[0].length);
      }
      else {
        result.push(pattern.charAt(0));
        pattern = pattern.slice(1);
      }
    }
    return result.join(‘‘);
  };

  $.formatDate.patternParts =
    /^(yy(yy)?|M(M(M(M)?)?)?|d(d)?|EEE(E)?|a|H(H)?|h(h)?|m(m)?|s(s)?|S)/;

  $.formatDate.monthNames = [
    ‘January‘,‘February‘,‘March‘,‘April‘,‘May‘,‘June‘,‘July‘,
    ‘August‘,‘September‘,‘October‘,‘November‘,‘December‘
  ];

  $.formatDate.dayNames = [
    ‘Sunday‘,‘Monday‘,‘Tuesday‘,‘Wednesday‘,‘Thursday‘,‘Friday‘,
    ‘Saturday‘
  ];

  $.formatDate.patternValue = {
    yy: function(date) {
      return $.toFixedWidth(date.getFullYear(),2);
    },
    yyyy: function(date) {
      return date.getFullYear().toString();
    },
    MMMM: function(date) {
      return $.formatDate.monthNames[date.getMonth()];
    },
    MMM: function(date) {
      return $.formatDate.monthNames[date.getMonth()].substr(0,3);
    },
    MM: function(date) {
      return $.toFixedWidth(date.getMonth()+1,2);
    },
    M: function(date) {
      return date.getMonth()+1;
    },
    dd: function(date) {
      return $.toFixedWidth(date.getDate(),2);
    },
    d: function(date) {
      return date.getDate();
    },
    EEEE: function(date) {
      return $.formatDate.dayNames[date.getDay()];
    },
    EEE: function(date) {
      return $.formatDate.dayNames[date.getDay()].substr(0,3);
    },
    HH: function(date) {
      return $.toFixedWidth(date.getHours(),2);
    },
    H: function(date) {
      return date.getHours();
    },
    hh: function(date) {
      var hours = date.getHours();
      return $.toFixedWidth(hours>12 ? hours - 12 : hours,2);
    },
    h: function(date) {
      return date.getHours()%12;
    },
    mm: function(date) {
      return $.toFixedWidth(date.getMinutes(),2);
    },
    m: function(date) {
      return date.getMinutes();
    },
    ss: function(date) {
      return $.toFixedWidth(date.getSeconds(),2);
    },
    s: function(date) {
      return date.getSeconds();
    },
    S: function(date) {
      return $.toFixedWidth(date.getMilliseconds(),3);
    },
    a: function(date) {
      return date.getHours() < 12 ? ‘AM‘ : ‘PM‘;
    }
  };

  $.toFixedWidth = function(value,length,fill) {
    var result = (value || ‘‘).toString();
    fill = fill || ‘0‘;
    var padding = length - result.length;
    if (padding < 0) {
      result = result.substr(-padding);
    }
    else {
      for (var n = 0; n < padding; n++) result = fill + result;
    }
    return result;
  };

})(jQuery);

 

以上是关于一个方便的日期格式器的主要内容,如果未能解决你的问题,请参考以下文章

Android 日期选择器片段更改为微调器

在片段中创建日期选择器

如何从片段中调用 getSupportFragmentManager()?

如何从我的 DatePicker 片段中传输格式化的日期字符串?

日期选择器上诉破裂

软输入键盘隐藏编辑文本