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

    技术2022-05-11  106

    【来源: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下载源码和用户手册。

       

    最新回复(0)