您的位置:首页 > Web前端 > JavaScript

如何使用Javascript格式化日期显示

2007-09-29 11:05 603 查看
【来源:JsJava官方中文博客

  我们都知道在Java和PHP语言中,有专门用于格式化日期对象的类和函数,例如Java中的DateFormat等等,通过这些类和函数,我们可以方便的将一个日期对象按照格式的要求输出为字符串,例如对于同一个日期2006年12月25日,需要的显示格式可能如下:

  2006年12月25日,2006-12-25,12-25-2006等等。

  在Javascript之中,日期对象是Date,那么如何将一个日期对象按照定制的格式进行输出呢?

  可以现告诉你,Date对象有有四个内置方法,用于输出为字符串格式,分别为:

  1)toGMTString,将一个日期按照GMT格式显示
  2)toLocaleString,将一个日期按照本地操作系统格式显示
  3)toLocaleDateString,按照本地格式显示一个日期对象的日期部分
  4)toLocaleTimeString,按照本地格式显示一个日期对象的时间部分

  尽管Javascript的Date对象中内置提供了这些输出为字符串的方法,但是这些字符串不是我们来控制格式的,因此如果我们需要我们自己定制的特殊格式,那么又该怎么办呢?

  不用着急,JsJava中提供了专用的类,专门对日期进行指定格式的字符串输出,你可以下载JsJava-1.0.zip,引入其中的src/jsjava/text/DateFormat.js,或者直接引入jslib/jsjava-1.0.js,样例代码如下:

    var df=new DateFormat();//注意2.0版本中使用其子类SimpleDateFormat
    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的官方文档,做了适当修改):

 

Letter Date or Time Component Presentation Examples
G
Era designator Text
AD
y
Year Year
1996
;
96
M
Month in year Month
July
;
Jul
;
07
w
Week in year Number
27
W
Week in month Number
2
D
Day in year Number
189
d
Day in month Number
10
F
Day of week in month Number
2
E
Day in week Text
Tuesday
;
Tue
a
Am/pm marker Text
PM
H
Hour in day (0-23) Number
0
k
Hour in day (1-24) Number
24
K
Hour in am/pm (0-11) Number
0
h
Hour in am/pm (1-12) Number
12
m
Minute in hour Number
30
s
Second in minute Number
55
S
Millisecond Number
978
  JsJava是非常强大的,可以说是Web项目中不可或缺的一个Javascript类库,它可以帮助你快速的解决客户端编程的许多问题,你可以去http://www.jsjava.com下载源码和用户手册。

 
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息