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

简介: 我们必须承认,JavaScript内建的Date方法实在是太基础了,远不够我们来处理日期。总有人会开发自己的JavaScript日期操作库,为何在能够使用已经开发并测试好的日期插件时还要再自己造个轮子呢。

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

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

以下列出6种插件:

1、Datejs

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

Datejs

01 // What date is next thrusday?
02 Date.today().next().thursday();
03    
04 // Add 3 days to Today
05 Date.today().add(3).days();
06    
07 // Is today Friday?
08 Date.today().is().friday();
09    
10 // Number fun
11 (3).days().ago();
12    
13 // 6 months from now
14 var n = 6;
15 n.months().fromNow();
16    
17 // Set to 8:30 AM on the 15th day of the month
18 Date.today().set({ day: 15, hour: 8, minute: 30 });
19    
20 // Convert text into Date
21 Date.parse('today');
22 Date.parse('t + 5 d'); // today + 5 days
23 Date.parse('next thursday');
24 Date.parse('February 20th 1973');
25 Date.parse('Thu, 1 July 2004 22:30:00');

2、Pretty Date

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

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

3、Moment JS

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

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

Moment JS

4、Countdown JS

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

5、XDate

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

XDate

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

6、DP Date Extension

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

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

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

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

  • 添加转换几个W3C草稿中描述的ISO 8601标准日期格式

英文地址,OSCHINA 原创翻译

目录
相关文章
|
28天前
|
JavaScript 前端开发
JavaScript操作DOM元素
JavaScript操作DOM元素
11 1
|
1月前
|
JavaScript 前端开发
如何使用 JavaScript 操作 DOM?
如何使用 JavaScript 操作 DOM?
13 0
|
1月前
|
JavaScript
JS设置日期为0时0分0秒
项目中经常要给设置默认值,搜索从哪天开始,这时候,如果直接通过new Date()来获取时间,会有时分秒,如果快速设置为0时0分0秒?
26 0
|
1月前
|
移动开发 前端开发 JavaScript
编程笔记 html5&css&js 005 网页上都有哪内容、形式和操作
编程笔记 html5&css&js 005 网页上都有哪内容、形式和操作
|
2月前
|
JavaScript 前端开发 安全
使用 Node.js 插件给指定目录下的所有图片添加上文字水印
使用 Node.js 插件给指定目录下的所有图片添加上文字水印
56 0
|
2月前
|
移动开发 JavaScript 前端开发
分享76个时间日期JS特效,总有一款适合您
分享76个时间日期JS特效,总有一款适合您
30 0
|
2月前
|
JavaScript 数据处理
JS 取整,取余操作
JS 取整,取余操作
|
3月前
|
JavaScript 前端开发
javascript 如何判断字符串日期是否相差七天
在JavaScript中,你可以使用`Date`对象来比较两个日期之间的差异。下面是一个简单的示例,演示如何判断两个字符串日期是否相差七天: ```javascript function isSevenDaysDifference(date1, date2) { // 确保输入是字符串 if (typeof date1 !== 'string' || typeof date2 !== 'string') { return false; } // 将字符串转换为Date对象 var d1 = new Date(date1);
|
2月前
|
JavaScript 前端开发 UED
分享89个时间日期JS特效,总有一款适合您
分享89个时间日期JS特效,总有一款适合您
29 3
|
4天前
|
存储 JavaScript 前端开发
JavaScript DOM 操作:解释一下 cookie、sessionStorage 和 localStorage 的区别。
Cookie是服务器发送至客户端的文本信息,会随每个请求发送回服务器,适合控制会话状态但可能暴露隐私。SessionStorage仅在当前会话中存储数据,关闭浏览器后清除,适合临时存储如登录状态。LocalStorage则持久保存数据,即使关闭浏览器也不会清除,适用于存储长期设置。三种方式各有侧重,应按需求选择。
9 0