返回列表

javascript Date format(js日期格式化)

默认分类 2011-05-16 07:30:54

转载:http://blog.csdn.net/hemingwang0902/archive/2009/09/02/4511130.aspx

最近在给中国证券网做网站改版的时候碰到这么一个问题, 在各个地方时间的显示格式都不一样, 各有各的风格, 有的地方要用
yyyy-MM-dd 格式的, 有的地方又要用 HH:mm:ss 格式的, 而有的地方又要用 yy-MM-dd HH:mm 格式的, 而后台往 XML 文件中写入的时候统一都是写的 yyyy-MM-dd HH:mm:ss.SSS 格式的, 于是在网上搜索了一下"js date format", 搜索出来的结果是大把大把的, 于是乎一个一个网页的打开瞧瞧, 最后终于被我找着了两个既好用,代码又易懂的, 现在贴出来给大家参考参考。

下面是第一个, 来源:http://blog.csdn.net/yuyue618/archive/2009/04/15/4074793.aspx

  1. <script language="javascript" type="text/javascript"
  2. <!--    
  3. /**     
  4.  * 对Date的扩展,将 Date 转化为指定格式的String    
  5.  * 月(M)、日(d)、12小时(h)、24小时(H)、分(m)、秒(s)、周(E)、季度(q) 可以用 1-2 个占位符     
  6.  * 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)    
  7.  * eg:     
  8.  * (new Date()).pattern("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423     
  9.  * (new Date()).pattern("yyyy-MM-dd E HH:mm:ss") ==> 2009-03-10 二 20:09:04     
  10.  * (new Date()).pattern("yyyy-MM-dd EE hh:mm:ss") ==> 2009-03-10 周二 08:09:04     
  11.  * (new Date()).pattern("yyyy-MM-dd EEE hh:mm:ss") ==> 2009-03-10 星期二 08:09:04     
  12.  * (new Date()).pattern("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18     
  13.  */      
  14. Date.prototype.pattern=function(fmt) {       
  15.     var o = {       
  16.     "M+" : this.getMonth()+1,//月份       
  17.     "d+" : this.getDate(),//日       
  18.     "h+" : this.getHours()%12 == 0 ? 12 : this.getHours()%12, //小时       
  19.     "H+" : this.getHours(),//小时       
  20.     "m+" : this.getMinutes(),//分       
  21.     "s+" : this.getSeconds(),//秒       
  22.     "q+" : Math.floor((this.getMonth()+3)/3),//季度       
  23.     "S" : this.getMilliseconds()//毫秒       
  24.     };       
  25.     var week = {       
  26.     "0" : "\u65e5",       
  27.     "1" : "\u4e00",       
  28.     "2" : "\u4e8c",       
  29.     "3" : "\u4e09",       
  30.     "4" : "\u56db",       
  31.     "5" : "\u4e94",       
  32.     "6" : "\u516d"      
  33.     };       
  34.     if(/(y+)/.test(fmt)){       
  35.         fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length));       
  36.     }       
  37.     if(/(E+)/.test(fmt)){       
  38.         fmt=fmt.replace(RegExp.$1, ((RegExp.$1.length>1) ? (RegExp.$1.length>2 ? "\u661f\u671f" : "\u5468") : "")+week[this.getDay()+""]);       
  39.     }       
  40.     for(var kin o){       
  41.         if(new RegExp("("+ k +")").test(fmt)){       
  42.             fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));       
  43.         }       
  44.     }       
  45.     return fmt;       
  46. }     
  47. var date = new Date();    
  48. window.alert(date.pattern("yyyy-MM-dd hh:mm:ss")); 
  49. // --> 
  50. </script>   
 

这是第二个,是一个老外写的, 来源:http://blog.csdn.net/akunshenjk/archive/2008/06/12/2539638.aspx

  1. Date.prototype.format = function(mask) {    
  2.     var d = this;    
  3.     var zeroize = function (value, length) {    
  4.         if (!length) length = 2;    
  5.         value = String(value);    
  6.         for (var i = 0, zeros = ''; i < (length - value.length); i++) {    
  7.             zeros += '0';    
  8.         }    
  9.         return zeros + value;    
  10.     };      
  11.     return mask.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|m{1,4}|yy(?:yy)?|([hHMstT])\1?|[lLZ])\b/g,function($0) {    
  12.         switch($0) {    
  13.            case 'd':   return d.getDate();    
  14.            case 'dd'return zeroize(d.getDate());    
  15.            case 'ddd': return ['Sun','Mon','Tue','Wed','Thr','Fri','Sat'][d.getDay()];    
  16.            case 'dddd':    return ['Sunday','Monday','Tuesday','Wednesday','Thursday','Friday','Saturday'][d.getDay()];    
  17.            case 'M':   return d.getMonth() + 1;    
  18.            case 'MM'return zeroize(d.getMonth() + 1);    
  19.            case 'MMM': return ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'][d.getMonth()];    
  20.            case 'MMMM':    return ['January','February','March','April','May','June','July','August','September','October','November','December'][d.getMonth()];    
  21.            case 'yy'return String(d.getFullYear()).substr(2);    
  22.            case 'yyyy':    return d.getFullYear();    
  23.            case 'h':   return d.getHours() % 12 || 12;    
  24.            case 'hh'return zeroize(d.getHours() % 12 || 12);    
  25.            case 'H':   return d.getHours();    
  26.            case 'HH'return zeroize(d.getHours());    
  27.            case 'm':   return d.getMinutes();    
  28.            case 'mm'return zeroize(d.getMinutes());    
  29.            case 's':   return d.getSeconds();    
  30.            case 'ss'return zeroize(d.getSeconds());    
  31.            case 'l':   return zeroize(d.getMilliseconds(), 3);    
  32.            case 'L':   var m = d.getMilliseconds();    
  33.                    if (m > 99) m = Math.round(m / 10);    
  34.                    return zeroize(m);    
  35.            case 'tt'return d.getHours() < 12 ? 'am' : 'pm';    
  36.            case 'TT'return d.getHours() < 12 ? 'AM' : 'PM';    
  37.            case 'Z':   return d.toUTCString().match(/[A-Z]+$/);    
  38.            // Return quoted strings with the surrounding quotes removed   
  39.            default:    return $0.substr(1, $0.length - 2);    
  40.         }    
  41.     });    
  42. };