本文摘自PHP中文网,作者不言,侵删。
本篇文章给大家带来的内容是关于Date对象常用的封装方法及遇到的问题解决,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
使用JS中的Date对象已经很久了,但是一直以来都没有将常用的封装函数和遇到的坑记录下来,趁着今天有空,就记录下来,方便自己下次直接使用,并提醒自己遇到过那些坑。如果有哪些地方不对,希望大家能够指出,那我将不胜感激。
在将日期(没有时分秒)转换为时间戳时,日期在用'-'(2019-01-01)和'/'(2019/01/01)连接时,转换成时间戳的结果有所差异
为了不让大家先看见例子太多而厌烦,就先上结论了。
结论:
1)如果日期之间是使用 '-'连接时,当月份和天数都小于9且前面加了一个 0 的话,那么被转为时间戳时会将时间默认转换为当天的上午8点
2)如果日期之间是使用 '-'连接时,当月份和天数有一个小于9且小于9的前面加了一个 0 的话,那么被转为时间戳时会将时间默认转换为当天的上午8点
3)如果日期之间是使用 '-'连接时,当月份和天数都小于9且只有一个前面加了一个 0 的话,那么被转为时间戳时会将时间默认转换为当天的上午12点也就是00:00
4)如果日期之间是使用 '-'连接时,当月份和天数都大于9时,那么被转为时间戳时会将时间默认转换为当天的上午8点
5)如果日期之间是使用 '/'连接时,那么转换成时间戳时只会被转换为当天的凌晨 00:00
总结: 在将日期转换为时间戳时,如果没有设置时分时,最好使用 '/' 来进行连接,来避免相同日期在写法不同时获取的时间戳不同
下面的是用来证明结论的例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | "
let time1 = new Date ( '2019-03-03' ).getTime();
let time2 = new Date ( '2019/3/3' ).getTime();
console.log( '获取时间' )
console.log(time1)
console.log(time2)
console.log( (time1-time2) / 1000 /60 /60 )
console.log( new Date ( '2019-03-03' ).toLocaleString())
console.log( new Date ( '2019-03-12' ).toLocaleString())
console.log( new Date ( '2019-11-03' ).toLocaleString())
console.log( new Date ( '2019-3-03' ).toLocaleString())
console.log( new Date ( '2019-03-3' ).toLocaleString())
console.log( new Date ( '2019-11-13' ).toLocaleString())
console.log( new Date ( '2019/03/03' ).toLocaleString())
console.log( new Date ( '2019/3/3' ).toLocaleString())
console.log( new Date ( '2019/03/3' ).toLocaleString())
console.log( new Date ( '2019/3/03' ).toLocaleString())
console.log( new Date ( '2019/03/12' ).toLocaleString())
console.log( new Date ( '2019/11/03' ).toLocaleString())
"
|
将日期格式转换为时间戳和将时间戳转换为日期格式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | 1. 将日期格式转换为时间戳的三种方法
"javascript
let dateStr = new Date ( '2019-3-20 18:59:39:123' );
let timestamp1 = dateStr.getTime();
let timestamp2 = dateStr.valueOf();
let timestamp3 = Date .parse(dateStr);
"
date .getTime()、 date .valueOf()会精确到毫秒,而 Date .parse( date )只能精确到秒,毫秒用000替代
2. 将时间戳转换为日期格式
"javascript
function dateFormat(timestamp) {
timestamp = (timestamp + '' ).length > 10 ? timestamp : timestamp * 1000;
let date = new Date (timestamp);
let year = date .getFullYear();
let month = date .getMonth() + 1 > 9 ? date .getMonth() + 1 : '0' + ( date .getMonth() + 1);
let day = date . getDate () > 9 ? date . getDate () : '0' + date . getDate () ;
let hour = date .getHours() > 9 ? date .getHours() : '0' + date .getHours() ;
let minutes = date .getMinutes() > 9 ? date .getMinutes() : '0' + date .getMinutes();
let seconds = date .getSeconds() > 9 ? date .getSeconds() : '0' + date .getSeconds();
return year + '-' + month + '-' + day + ' ' + hour + ':' + minutes + ':' + seconds;
}
"
|
比较两个日期之间相隔多少天
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
getIntervalDay( '2019-03-03' , '2019-03-8' );
function getIntervalDay(beginTime, endTime) {
beginTime = beginTime.replace(/\-/g, '/' );
endTime = endTime.replace(/\-/g, '/' );
let time1 = new Date (beginTime).getTime();
let time2 = new Date (endTime).getTime();
let second = time2 - time1;
let day = parseInt(second / (1000 * 60 * 60 * 24)) + 1;
return day;
}
|
判断一年有多少天
1 2 3 4 5 6 | function getYearAllDay(year) {
return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0 ? 366 : 365;
}
|
获取某年的一个月的总天数
1 2 3 4 5 6 7 8 9 10 | function getMonthAllDay( date ) {
date = new Date ( date );
let year = date .getFullYear();
let month = date .getMonth() + 1;
let nextMonth = year + '-' + (month + 1);
let newDate = new Date (nextMonth);
newDate.setDate(0);
return newDate. getDate ();
}
|
本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注PHP中文网的JavaScript教程视频栏目!以上就是Date对象常用的封装方法及遇到的问题解决的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
javascript dom方法有哪些
js怎么删除数组中指定元素?
除了 async 速度翻 10 倍,javascript 还带来了什么?
如何将 javascript 回调转换为 promise?方法介绍
javascript实现递归算法的方法介绍
360怎么开启javascript
值得收藏的20个前端开发icon图标库
你可能不知道的chrome debug专用的函数!
javascript常用属性方法有哪些
什么是javascript引擎
更多相关阅读请进入《javascript》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » Date对象常用的封装方法及遇到的问题解决