6个强大的JavaScript日期操作插件(翻译)

彭博 发布于 2012/03/13 18:41
阅读 5K+
收藏 116

我们必须承认,JavaScript内建的Date方法实在是太基础了,远不够我们来处理日期。总有人会开发自己的JavaScript日期操作库,为何在能够使用已经开发并测试好的日期插件时还要再自己造个轮子呢。我已经碰到过很多次需要操作日期格式的情形,这些插件将节约大把的时间。

以下插件都拥有许多例如以不同格式显示日期、显示相对时间(如:20分钟前)等特性,他们其中适合于处理两天之间的倒计时。

以下列出6种插件:

1、Datejs

Datejs 是一个开源的JavaScript库,用来解析、格式化和处理日期数据,支持多种语言的日期格式处理。

Datejs

// What date is next thrusday?
Date.today().next().thursday();
  
// Add 3 days to Today
Date.today().add(3).days();
  
// Is today Friday?
Date.today().is().friday();
  
// Number fun
(3).days().ago();
  
// 6 months from now
var n = 6;
n.months().fromNow();
  
// Set to 8:30 AM on the 15th day of the month
Date.today().set({ day: 15, hour: 8, minute: 30 });
  
// Convert text into Date
Date.parse('today');
Date.parse('t + 5 d'); // today + 5 days
Date.parse('next thursday');
Date.parse('February 20th 1973');
Date.parse('Thu, 1 July 2004 22:30:00');

2、Pretty Date

Prettydate 是一个 jQuery 用来显示一些用户友好的日期格式的插件,例如 Posted 2 days ago by John Resig

prettyDate("2008-01-28T20:24:17Z") // => "2 hours ago"
prettyDate("2008-01-27T22:24:17Z") // => "Yesterday"
prettyDate("2008-01-26T22:24:17Z") // => "2 days ago"
prettyDate("2008-01-14T22:24:17Z") // => "2 weeks ago"
prettyDate("2007-12-15T22:24:17Z") // => undefined 

3、Moment JS

Moment.js 是一个简单易用的轻量级JavaScript日期处理类库,提供了日期格式化、日期解析等功能。它支持在浏览器和NodeJS两种环境中运行。此类库能够 将给定的任意日期转换成多种不同的格式,具有强大的日期计算功能,同时也内置了能显示多样的日期形式的函数。另外,它也支持多种语言,你可以任意新增一种 新的语言包。

//Return relative duration, eg 5 months ago
var halloween = moment([2011, 9, 31]);
console.log(halloween.fromNow());
 
// Return current date plus 9
var now = moment().add('days', 9);
console.log(now.format('dddd, MMMM Do YYYY'));

Moment JS

4、Countdown JS

Countdown是jQuery的一个用于显示倒计时的插件Countdown JS

5、XDate

XDate是一个对Javascirpt本地Date对象的轻度包装,它提供对日期的解析、格式化以及其他操作的较强功能。它实现了本地Date对象的相同方法。

XDate

d = new XDate(2011, 7, 31); // August 31
d.setMonth(8); // September
d.toString(); // October 1st!!! because there are only 30 says in September
 
// let's try this with preventOverflow...
d = new XDate(2011, 7, 31); // August 31
d.setMonth(8, true); // September
d.toString(); // September 30!

6、DP Date Extension

DP_DateExtensions库继承了JavaScript的Date对象,并添加了一些新特性和功能。

  • 添加了富特性的timeFormat()以及dateFormat()方法,允许你对时间和日期值进行微操

  • 通过add()和diff()方法轻松操作日期

  • 通过新的compare()方法简化日期的比较

  • 添加转换几个W3C草稿中描述的ISO 8601标准日期格式
英文地址,OSCHINA 原创翻译
加载中
0
antipro
antipro
日期操作在编程中确实经常出现。
0
GeorgeWorld
GeorgeWorld
建议把日期选择框的截图发上来,而不是logo。
j
jovi
这些应该都是没有UI的.
0
hokim
hokim

貌似都只能处理英文日期    

 

0
littlecong
littlecong

引用来自“GeorgeWorld”的答案

建议把日期选择框的截图发上来,而不是logo。

都不是日期选择框呀

0
一酷
一酷
我也理解错误,以为是日期选择插件
0
iamlile
iamlile
日期操作,是常事
0
lemonseed
lemonseed
洒家也误解啦。。
0
灿若星空
这个嘛,可以试一试吧!!
返回顶部
顶部