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

转载 2007年09月29日 11:05:00

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

 
 

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

我们都知道在Java和PHP语言中,有专门用于格式化日期对象的类和函数,例如Java中的DateFormat等等,通过这些类和函数,我们可以方便的将一个日期对象按照格式的要求输出为字符串,例如对于同一...
  • xzknet
  • xzknet
  • 2008年04月10日 15:49
  • 5846

javascript 格式化日期

今天发个javascript的格式化日期的工具函数,给自己做个备忘记录,也发上来给需要的人。呵呵~~~ /** * 格式化日期 * @param {Object} ms 表示指定日期与 ...
  • lazy_p
  • lazy_p
  • 2011年04月12日 17:26
  • 821

javascript格式化日期

在java中存入的时间戳是13位的,那么在javascript处理的不需要任何处理,即可得到日期格式的时间 var d = new Date(); console.log(d); // 输...
  • sd4015700
  • sd4015700
  • 2014年03月31日 16:25
  • 367

JS之格式化日期函数

获取当前时间的格式化字符 function getNowFormatDate() { //“yyyy-MM-dd HH:MM:SS” var ...
  • zt_fucker
  • zt_fucker
  • 2017年04月17日 17:03
  • 149

JavaScript格式化日期

JavaScript格式化日期,直接上代码 function format2Date(date,fmt) { var o = { "M+": date.getMonth() + 1, ...
  • chmod_R_755
  • chmod_R_755
  • 2017年06月19日 10:22
  • 316

javascript格式化日期

 将String类型解析为Date类型.   parseDate(2006-1-1) return new Date(2006,0,1)   parseDate( 2006-1-1 ) return ...
  • livening
  • livening
  • 2009年12月29日 12:42
  • 811

JS中日期格式化的方法

1. 2. 3.
  • William0318
  • William0318
  • 2016年12月20日 15:45
  • 229

jquery 格式化日期显示

// 对Date的扩展,将 Date 转化为指定格式的String // 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符,  // 年(y)可以用 1-4...
  • u013239233
  • u013239233
  • 2016年09月02日 10:08
  • 135

用javaScript(js)格式化日期

用javaScript(js)格式化日期
  • Cike121272604
  • Cike121272604
  • 2010年08月13日 14:30
  • 271

WebWork/struts2中格式化输出数字和日期的方法

truts2的匹配模式详情请见http://java.sun.com/docs/books/tutorial/i18n/format/decimalFormat.html 可以在资源文件中定义日期及其...
  • swandragon
  • swandragon
  • 2009年10月25日 11:56
  • 1262
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:如何使用Javascript格式化日期显示
举报原因:
原因补充:

(最多只允许输入30个字)