今天我就只说 setFullYear, setMonth, setDate,因为今天的应用只涉及到这三个。
这3个方法顾名思义分别设置年、月、日,之前我所了解到的应用,比如“倒计时”中设置目标时间点的时候会用到,其他的暂时记不起来,回头再补。
今天来说说“获取当前月(季度/年)的最后一天”的用法
你可能想到了,每个月的天数是不应定的,有28、29(闰年2月)、30、31,总不能去算一下现在是几月份,然后去arr或者map(json)里边去找对应的日期吧,当然这也是个方法,能达到效果(还要考虑闰年)。
那么,不这么繁琐的话,怎么搞呢?
其实,Date本来就会自动处理每月的天数,包括闰年什么的特殊情况,所以,这个我们根本不用去关心。
这里用到一个用法,估计大家有可能也用过,date.setDate(0)。没错,你没看错,就是0。(喂,这不是month啊,不用加1,你确定不是要用setDate(1) ?)
0是不存在的一天,date.setDate(0)之后,这一天不存在,或者说设置的是1号的前一天。那么,1号的前一天,自然就是前一个月的最后一天
var date = new Date(); console.log('今天是 ', date.getMonth() + 1, date.getDate()); date.setDate(0); console.log('上个月最后一天是 ', date.getMonth() + 1, date.getDate());
控制台跑一下上边代码,就会得到上个月最后一天了。
继续,我们要得到的是这个月最后一天,怎么破
先把月份设置到下个月,然后获取这个月最后一天:
date.setMonth(date.getMonth() + 1); date.setDate(0);
date就是这个月最后一天对应的date对象。
到此,简单地获取当月最后一天已经完了,改变setMonth可以让你获取任何一个月的最后一天了。
~~~~~~~~~~~~~~~~~~~~~~~~~ 分割线 ~~~~~~~~~~~~~~~~~~~~~~
下面,来讲获取这一年的最后一天的date。
同理,我们只要设置到明年就可以了,然后设置月份到0月(就是1月),然后设置到0日,这样就成了2017-01-00,也就是元旦的前一天,当然也就是2016-12-31这天了。
date.setFullYear(date.getFullYear() + 1); // 设置到明年 date.setMonth(0); // 明年的0月,也就是对应到1月,是存在的哦,不是不存在的0 date.setDate(0); // 明年的0日
~~~~~~~~~~~~~~~~~~~~~~~~~ 又来分割线 ~~~~~~~~~~~~~~~~~~~~~
然后,又到了获取当前季度的最后一天。
Date中是没有季度的概念的(如果有,请及时告诉我,让我多个知识点),所以,首先我们要判断当前月在哪个季度
var m = date.getMonth(); var quarter = Math.floor(m / 3) + 1; // 从1开始,到4 var qLastMonth = quarter * 3;
其中,quarter 是第几季度,qLastMonth 是这个季度的最后一个月是几月 // 从1开始到12,当年可以减去1,从0到11。
既然拿到了这个季度的最后一个月是几月,那再用上边的获取任一月份的最后天的方法来处理就好了
date.setMonth(qLastMonth); date.setDate(0);
这时候,date就是当前季度的最后一天的date对象了。当然,做一下扩展就可以拿到任意季度的最后一天,只要在第一步设置(喂喂,干嘛呢,绕远了)
要拿到任意季度的最后一天,比如第2季度,只需要。。。
date.setMonth(6); // 4 || 5 || 6 都行 date.setDate(0);
最后,来一个项目中遇到的实际应用里子
是酱紫的:
- 获取本季度的最后一天; 当今天是当前季度最后一天切大于15日的时候(比如6月20日),返回下个季度的最后一天。
- 获取本年最后一天;当今天是大于12月15日的时候,返回明年的最后一天。
开始的实现代码如下:
/** * 获取 当前月/当前年/当前季度 的最后一天的date对象 * @param {String} type 类型选择: month/m, year/y, quarter/q * @return {object} 最后一天的date对象,目前只可用到天 */ var SERVER_TIME = Date.now() / 1000; // 服务器时间,这里用本地时间代替 function getMaxDate(type) { var date = new Date(SERVER_TIME * 1000); var m = date.getMonth(); var y = date.getFullYear(); var d = date.getDay(); var today = date.getDate(); console.log(['SERVERTIME: ',y,'-',m+1,'-',today,' 星期',d].join('')); switch (type) { case 'm': case 'month': date.setMonth(m + 1); date.setDate(0); break; case 'y': case 'year': if (m == 11 && today >= 15) { date.setFullYear(y + 2); } else { date.setFullYear(y + 1); } date.setMonth(0); date.setDate(0); break; case 'q': case 'quarter': var qLastMonth = (Math.floor(m / 3) + 1) * 3; date.setMonth(qLastMonth); date.setDate(0); if (m === date.getMonth() && today >= 15) { date.setMonth(qLastMonth + 3); date.setDate(0); } break; default: date = null; } return date; }
然后,这段代码有个大坑,平时还不一定能遇到,这不到年底了么,它就出来了(还好不是千年虫之类的千年一遇)
季度选择的时候,36行或导致后边的38行的代码块出问题。
比如第2季度,是没有问题的。36行设置date的日到30号,即6月30日;假如满足38行代码逻辑的话,39-40行设置月份到9月30日,没毛病,完美~
但是,假如现在是第1季度,36行设置日期到3月31日;假如满足38行代码逻辑的话,39-40行设置月份到6月31日,阿西吧,6月没有31日,那么这时候得到的date,就会是~~~~没错,7月1日,自挖坑啊。
所以,改代码
function getMaxDate(type) { var date = new Date(SERVER_TIME * 1000); var m = date.getMonth(); var y = date.getFullYear(); var d = date.getDay(); var today = date.getDate(); console.log(['SERVERTIME: ', y, '-', m + 1, '-', today, ' 星期', d].join('')); switch (type) { case 'm': case 'month': date.setMonth(m + 1); date.setDate(0); break; case 'y': case 'year': if (m == 11 && today >= 15) { date.setFullYear(y + 2); } else { date.setFullYear(y + 1); } date.setMonth(0); date.setDate(0); break; case 'q': case 'quarter': var qLastMonth = (Math.floor(m / 3) + 1) * 3; if (m === date.getMonth() && today >= 15) { date.setMonth(qLastMonth + 3); } else { date.setMonth(qLastMonth); } date.setDate(0); // 得到当前季度最后一天的date break; default: date = null; } return date; }
这里得到一个注意项,月份的相关判断,一定要在日的设置之前做好,不要再日期设置后在操作月份;或者你把日期设置到1-28之间任意数字,也就是保证不会跑到下一个月去。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]