使用moment.js轻松管理日期和时间

时间插件Moment.js使用

大家在前端Javascript开发中会遇到处理日期时间的问题,经常会拿来一大堆处理函数才能完成一个简单的日期时间显示效果。今天我给大家介绍一个轻量级的Javascript日期处理类库:moment.js,使用它可以轻松解决前端开发中遇到的种种日期时间问题。另外还增加了Moment Timezon JavaScript 时区处理类库

英文官网:http://momentjs.com/

中文官网:http://momentjs.cn/

使用moment.js轻松管理日期和时间

moment.js不依赖任何第三方库,支持字符串、Date、时间戳以及数组等格式,可以像PHP的date()函数一样,格式化日期时间,计算相对时间,获取特定时间后的日期时间等等,支持多种语言国际化操作,本文有如下举例。

日期格式化

moment().format('MMMM Do YYYY, h:mm:ss a'); // 十二月 16日 2016, 4:25:17 下午
moment().format('dddd');                    // 星期五
moment().format("MMM Do YY");               // 12月 16日 16
moment().format('YYYY [escaped] YYYY');     // 2016 escaped 2016
moment().format();                          // 2016-12-16T16:25:17+08:00

相对时间

moment("20111031", "YYYYMMDD").fromNow(); // 5 年前
moment("20120620", "YYYYMMDD").fromNow(); // 4 年前
moment().startOf('day').fromNow();        // 16 小时前
moment().endOf('day').fromNow();          // 8 小时内
moment().startOf('hour').fromNow();       // 26 分钟前

日历时间

moment().subtract(10, 'days').calendar(); // 2016年12月6日
moment().subtract(6, 'days').calendar();  // 上周六下午4点26
moment().subtract(3, 'days').calendar();  // 本周二下午4点26
moment().subtract(1, 'days').calendar();  // 昨天下午4点26分
moment().calendar();                      // 今天下午4点26分
moment().add(1, 'days').calendar();       // 明天下午4点26分
moment().add(3, 'days').calendar();       // 下周一下午4点26
moment().add(10, 'days').calendar();      // 2016年12月26日

多语言支持

moment().format('L');    // 2016-12-16
moment().format('l');    // 2016-12-16
moment().format('LL');   // 2016年12月16日
moment().format('ll');   // 2016年12月16日
moment().format('LLL');  // 2016年12月16日下午4点27分
moment().format('lll');  // 2016年12月16日下午4点27分
moment().format('LLLL'); // 2016年12月16日星期五下午4点27分
moment().format('llll'); // 2016年12月16日星期五下午4点27分

其他

获取当前月份时间段
var firstDay = moment().startOf('month').format('YYYY-MM-DD'),
lastDay  = moment().endOf('month').format('YYYY-MM-DD');
获取3个月内的时间段:
var currentMonth = moment().month()+1,
currentYear  = moment().year(),
lastMonth    = currentMonth-3;
lastMonth    = (currentMonth-3)<10?'0'+lastMonth:lastMonth;
var lastDay = moment().startOf('month').format('YYYY-MM-DD'),
firstDay = currentYear +'-'+ lastMonsth + '-01';
获取本周时间段:
var firstDay = moment().day(0).format('YYYY-MM-DD'),
lastDay = moment().day(7).format('YYYY-MM-DD');

moment.js提供了丰富的说明文档,使用它还可以创建日历项目等复杂的日期时间应用。我们日常开发中最常用的是格式化时间,下面我把常用的格式制作成表格说明供有需要的朋友查看:

格式代码说明返回值例子
M数字表示的月份,没有前导零1到12
MM数字表示的月份,有前导零01到12
MMM三个字母缩写表示的月份Jan到Dec
MMMM月份,完整的文本格式January到December
Q季度1到4
D月份中的第几天,没有前导零1到31
DD月份中的第几天,有前导零01到31
d星期中的第几天,数字表示0到6,0表示周日,6表示周六
ddd三个字母表示星期中的第几天Sun到Sat
dddd星期几,完整的星期文本从Sunday到Saturday
w年份中的第几周如42:表示第42周
YYYY四位数字完整表示的年份如:2014 或 2000
YY两位数字表示的年份如:14 或 98
A大写的AM PMAM PM
a小写的am pmam pm
HH小时,24小时制,有前导零00到23
H小时,24小时制,无前导零0到23
hh小时,12小时制,有前导零00到12
h小时,12小时制,无前导零0到12
m没有前导零的分钟数0到59
mm有前导零的分钟数00到59
s没有前导零的秒数1到59
ss有前导零的描述01到59
XUnix时间戳1411572969



未经允许请勿转载:程序喵 » 使用moment.js轻松管理日期和时间

点  赞 (1) 打  赏
分享到: