寫在前面:
如題,就像題目說的需要計算出時間差,雖然不太難,但這個需求經常會在專案中遇到的,我在這邊做一下整理,希望能夠儘量全的整理出來。有需要的朋友可以做一下參考,喜歡的可以點波贊,或者關注一下,希望可以幫到大家。
本文首發於我的個人blog:obkoro1.com
計算時間差原理:
getTime()方法
方法定義: getTime() 方法可返回距 1970 年 1 月 1 日之間的毫秒數。
通常我們計算時間差都是通過獲取兩個時間資料,然後分別使用getTime()方法返回與固定的1970 年 1 月 1 日的時間差,通過對返回毫秒數的差,換算成時間單位,得出兩個時間的時間差。
開始操作:
首先你會有一串初始的時間資料,然後通過 new Date(你的時間資料),將你的資料轉成Date物件的形式。
var t1="2017/08/28 04:56:38"; //資料
var dateBegin = new Date(t1);//轉化為Date物件的形式
//Mon Aug 28 2017 04:56:38 GMT+0800 (中國標準時間) 這裡就是Date物件的資料形式複製程式碼
時間格式
這裡的話就要注意一下後端給的時間資料格式的問題,比如下面兩種:
第一種:"2017/08/28 04:56:38"//這種格式不用再進行處理
第二種:"2017-08-01 18:56:38"//這種格式就要進行處理複製程式碼
因為new Date()方法不能處理第二種資料,所以我們這裡需要將第二種資料格式轉化為第一種資料的格式。
var t1="2017-05-12 00:13:53";
var dateBegin = new Date(d1.replace(/-/g, "/"));//replace方法將-轉為/複製程式碼
不知道大家是什麼情況,反正因為我們後端給我的資料就是第二種的,所以我會提一下這個東西(捂臉)。
另一個時間資料:
既然是時間差的話,就肯定要有兩個資料,不然怎麼兩相比較,一般兩個資料中都會有一個當前時間的資料。
var dateEnd = new Date();//當前時間資料複製程式碼
完整計算時間差(天、小時、分鐘、秒)的程式碼:
先獲取之間的毫秒差,通過毫秒差換算出你所需要的時間單位,然後時間單位之間的換算根據的是他們的倍數關係。
function timeFn(d1) {//di作為一個變數傳進來
//如果時間格式是正確的,那下面這一步轉化時間格式就可以不用了
var dateBegin = new Date(d1.replace(/-/g, "/"));//將-轉化為/,使用new Date
var dateEnd = new Date();//獲取當前時間
var dateDiff = dateEnd.getTime() - dateBegin.getTime();//時間差的毫秒數
var dayDiff = Math.floor(dateDiff / (24 * 3600 * 1000));//計算出相差天數
var leave1=dateDiff%(24*3600*1000) //計算天數後剩餘的毫秒數
var hours=Math.floor(leave1/(3600*1000))//計算出小時數
//計算相差分鐘數
var leave2=leave1%(3600*1000) //計算小時數後剩餘的毫秒數
var minutes=Math.floor(leave2/(60*1000))//計算相差分鐘數
//計算相差秒數
var leave3=leave2%(60*1000) //計算分鐘數後剩餘的毫秒數
var seconds=Math.round(leave3/1000)
console.log(" 相差 "+dayDiff+"天 "+hours+"小時 "+minutes+" 分鐘"+seconds+" 秒")
console.log(dateDiff+"時間差的毫秒數",dayDiff+"計算出相差天數",leave1+"計算天數後剩餘的毫秒數"
,hours+"計算出小時數",minutes+"計算相差分鐘數",seconds+"計算相差秒數");
}
var t3="2017-08-18 04:56:38";
timeFn(t3);複製程式碼
不成熟的計算月、年:
//這裡的dayDiff就是上文計算出的天數差
let monthDiff=Math.floor(dayDiff/30);//以30天為一個月不夠精準嚴謹
//獲取相差的月份
if (monthDiff<12){
timeThis=monthDiff+"個月前釋出";//獲取相差的月份
return
}
let yearDiff=Math.floor(monthDiff/12);//獲取相差的年份
if(yearDiff>=1){
timeThis=yearDiff+"年前釋出";
return
}複製程式碼
當天數相差較大的時候,單純計算天數已經不能滿足需求了,因為我們PM說的統一以30天為一個月的分界線,然後這裡月份的計算情況感覺很複雜的樣子沒有繼續研究下去。
獲取當前月份的天數
function getDays() {
//構造當前日期物件
var date = new Date();
var year = date.getFullYear();//獲取年份
var mouth = date.getMonth() + 1;//獲取當前月份
var days;//定義當月的天數;
if (mouth == 2) {//當月份為二月時,根據閏年還是非閏年判斷天數
days = year % 4 == 0 ? 29 : 28;
}
else if (mouth == 1 || mouth == 3 || mouth == 5 || mouth == 7 || mouth == 8 || mouth == 10 || mouth == 12) {
//月份為:1,3,5,7,8,10,12 時,為大月.則天數為31;
days = 31;
}
else {
//其他月份,天數為:30.
days = 30;
}
return days;
}複製程式碼
網上找了個獲取當前月份天數的函式,上面的註釋也足夠全,我就一起貼上來,連線在下面。
後話
上面就是本文計算時間差的內容了,希望看完本文能給大家一點幫助。最後一個提示:一般需要處理的資料不會只有一兩個,很可能會給一個陣列,你需要處理每個陣列元素的時間資料,這時候建議用forEach()函式遍歷整個陣列。
最後:如需轉載,請放上原文連結並署名。碼字不易,感謝支援!本人寫文章本著交流記錄的心態,寫的不好之處,不撕逼,但是歡迎指點。然後就是希望看完的朋友點個喜歡,也可以關注一下我。
blog網站 and 掘金個人主頁
以上2017.10.15