当前位置: 移动技术网 > IT编程>开发语言>JavaScript > javascript中神奇的 Date对象小结

javascript中神奇的 Date对象小结

2017年12月12日  | 移动技术网IT编程  | 我要评论
date 对象算是较常用的对象之一,但很多人完全不会操作,就算一些简单的操作也用 moment 而不自己尝试一下。 本次分享下 date 中的 date 使用技巧,希望能

date 对象算是较常用的对象之一,但很多人完全不会操作,就算一些简单的操作也用 moment 而不自己尝试一下。

本次分享下 date 中的 date 使用技巧,希望能给大家启发。

mdn官网介绍

setdate() 方法根据本地时间来指定一个日期对象的天数。

如果 dayvalue 超出了月份的合理范围,setdate 将会相应地更新 date 对象。

例如,如果为 dayvalue 指定0,那么日期就会被设置为上个月的最后一天。

获取月份天数

// 获取月份天数
function getmonthdaycount(year, month) {
 return new date(year, month, 0).getdate();
}
console.log(getmonthdaycount(2017, 10)); // 31

date 第三个参数的本质跟 setdate 是一样的。

因为 date 为 0 时自动退到上个月的最后一天,所以这里月份也不需要减,正好的。

获取所有月份天数

function getallmonthdaycount(year) {
 var days = [31, new date(year, 2, 0).getdate(), 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
 return days;
}
console.log(getallmonthdaycount(2016));// [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]

这个算是上面的延伸,不多解释。

是否是闰年

function isleapyear(year) {
 return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0);
}

这是网上的代码,相信大多数人都用。

但其实你真的理解或者能记住么?

反正我不能。。

function isleapyear(year) {
 return new date(year, 2, 0).getdate() === 29;
}
console.log([
 isleapyear(2000),
 isleapyear(2016),
 isleapyear(2017),
 isleapyear(2018)
]); // [ true, true, false, false ]

这样看,是不是就非常简单容易理解了。

而且都不需要记,是不是想忘都忘不了?

天数加减操作

之前看到有人用相对秒数在计算几天前或几天后,甚至还在算跨月,跨年的情况。

其实直接 setdate 就好了,自动处理 跨月,跨年 的情况。

// 10天后是几月几号
var dt = new date('2016-12-25');
dt.setdate(dt.getdate() + 10);
console.log(dt.tolocaledatestring()); // 2017/1/4


// 10天前是几月几号
var dt = new date('2017-01-04');
dt.setdate(dt.getdate() - 10);
console.log(dt.tolocaledatestring()); // 2016/12/25

小结

虽然这些东西很基础,说方法名,可能大家都知道,但很多人却依然不会去使用。

就跟用 jq 却依然 for 循环处理结果一样。

这里只列举了部分例子,也许会有其他神奇的操作技巧等你去发现。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网