`

用JavaScript(js)对时间格式化

 
阅读更多

可以说是Web项目中不可或缺的一个Javascript类库,它可以帮助你快速的解决客户端编程的许多问题,下面贴出一个用js格式化时间的方法。

如果你看到这段文字,说明您正使用RSS阅读或转自《一棵树-博客园》,原文地址:http://www.cnblogs.com/atree/archive/2011/06/29/JS-JavaScript-Date-Format.html
Js代码
  1. Date.prototype.format=function(format)
  2. {
  3. varo={
  4. "M+":this.getMonth()+1,//month
  5. "d+":this.getDate(),//day
  6. "h+":this.getHours(),//hour
  7. "m+":this.getMinutes(),//minute
  8. "s+":this.getSeconds(),//second
  9. "q+":Math.floor((this.getMonth()+3)/3),//quarter
  10. "S":this.getMilliseconds()//millisecond
  11. }
  12. if(/(y+)/.test(format))format=format.replace(RegExp.$1,
  13. (this.getFullYear()+"").substr(4-RegExp.$1.length));
  14. for(varkino)if(newRegExp("("+k+")").test(format))
  15. format=format.replace(RegExp.$1,
  16. RegExp.$1.length==1?o[k]:
  17. ("00"+o[k]).substr((""+o[k]).length));
  18. returnformat;
  19. }

以上代码必须先声明,然后在使用。使用方法:

Js代码
  1. vard=newDate().format('yyyy-MM-dd');

另一种方法:

在Javascript之中,日期对象是Date,那么如何将一个日期对象按照定制的格式进行输出呢?
可以现告诉你,Date对象有有四个内置方法,用于输出为字符串格式,分别为:
1)toGMTString,将一个日期按照GMT格式显示
2)toLocaleString,将一个日期按照本地操作系统格式显示
3)toLocaleDateString,按照本地格式显示一个日期对象的日期部分
4)toLocaleTimeString,按照本地格式显示一个日期对象的时间部分
尽管Javascript的Date对象中内置提供了这些输出为字符串的方法,但是这些字符串不是我们来控制格式的,因此如果我们需要我们自己定制的特殊格式,那么又该怎么办呢?
不用着急,JsJava中提供了专用的类,专门对日期进行指定格式的字符串输出,你可以下载JsJava-2.0.zip,引入其中的 src/jsjava/text/DateFormat.js,或者直接引入jslib/jsjava-2.0.js,样例代码如下:

var df=new SimpleDateFormat();//jsJava1.0需要使用DateFormat对象,不要弄错就是了
df.applyPattern("yyyy-MM-dd HH:mm:ss");
var date=new Date(2007,3,30,10,59,51);
var str=df.format(date);
document.write(str);
//显示结果为:2007-04-30 10:59:51

通过上面的例子你可以看出,你需要做的就是指定pattern,那么pattern中yyyy、MM等都表示什么意思呢?如果你学习过Java的日 期格式化,那么你应该知道,那都是占位符,这些占位符都具有特殊的函数,例如y表示年,yyyy表示四个数字的年份,例如1982,下面列举一些 pattern中支持的特殊字符及其含义(下面表格引自Java的官方文档,做了适当修改):

Js代码
  1. GEradesignator[url=]Text[/url]AD
  2. yYear[url=]Year[/url]1996;96
  3. MMonthinyear[url=]Month[/url]July;Jul;07
  4. wWeekinyear[url=]Number[/url]27
  5. WWeekinmonth[url=]Number[/url]2
  6. DDayinyear[url=]Number[/url]189
  7. dDayinmonth[url=]Number[/url]10
  8. FDayofweekinmonth[url=]Number[/url]2
  9. EDayinweek[url=]Text[/url]Tuesday;Tue
  10. aAm/pmmarker[url=]Text[/url]PM
  11. HHourinday(0-23)[url=]Number[/url]0
  12. kHourinday(1-24)[url=]Number[/url]24
  13. KHourinam/pm(0-11)[url=]Number[/url]0
  14. hHourinam/pm(1-12)[url=]Number[/url]12
  15. mMinuteinhour[url=]Number[/url]30
  16. sSecondinminute[url=]Number[/url]55
  17. SMillisecond[url=]Number[/url]978
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics