溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS把字符串格式的時間轉換成幾秒前、幾分鐘前、幾小時前、幾天前等格式

發(fā)布時間:2020-09-21 02:22:18 來源:腳本之家 閱讀:218 作者:mrr 欄目:web開發(fā)

最近在做項目的時候,需要把后臺返回的時間轉換成幾秒前、幾分鐘前、幾小時前、幾天前等的格式;后臺返回的時間格式為:2015-07-30 09:36:10,需要根據(jù)當前的時間與返回的時間進行對比,最后顯示成幾秒前、幾分鐘前、幾小時前、幾天前的形式。

1.由于返回的時間是字符串格式,所以要先轉換成時間戳

//字符串轉換為時間戳
function getDateTimeStamp (dateStr) {
  return Date.parse(dateStr.replace(/-/gi,"/"));
}

2.將返回的時間戳與當前時間戳進行比較,轉換成幾秒前、幾分鐘前、幾小時前、幾天前的形式。

function getDateDiff (dateStr) {
  var publishTime = getDateTimeStamp(dateStr)/1000,
    d_seconds,
    d_minutes,
    d_hours,
    d_days,
    timeNow = parseInt(new Date().getTime()/1000),
    d,
    date = new Date(publishTime*1000),
    Y = date.getFullYear(),
    M = date.getMonth() + 1,
    D = date.getDate(),
    H = date.getHours(),
    m = date.getMinutes(),
    s = date.getSeconds();
    //小于10的在前面補0
    if (M < 10) {
      M = '0' + M;
    }
    if (D < 10) {
      D = '0' + D;
    }
    if (H < 10) {
      H = '0' + H;
    }
    if (m < 10) {
      m = '0' + m;
    }
    if (s < 10) {
      s = '0' + s;
    }
  d = timeNow - publishTime;
  d_days = parseInt(d/86400);
  d_hours = parseInt(d/3600);
  d_minutes = parseInt(d/60);
  d_seconds = parseInt(d);
  if(d_days > 0 && d_days < 3){
    return d_days + '天前';
  }else if(d_days <= 0 && d_hours > 0){
    return d_hours + '小時前';
  }else if(d_hours <= 0 && d_minutes > 0){
    return d_minutes + '分鐘前';
  }else if (d_seconds < 60) {
    if (d_seconds <= 0) {
      return '剛剛發(fā)表';
    }else {
      return d_seconds + '秒前';
    }
  }else if (d_days >= 3 && d_days < 30){
    return M + '-' + D + '&nbsp;' + H + ':' + m;
  }else if (d_days >= 30) {
    return Y + '-' + M + '-' + D + '&nbsp;' + H + ':' + m;
  }
}  

3.使用方法:

  dateStr:返回的時間字符串,格式如:2015-07-30 09:36:10

// 轉換后的結果 
var str = getDateDiff(dateStr);
// 在控制臺輸出結果 
console.log(str);

總結

以上所述是小編給大家介紹的JS把字符串格式的時間轉換成幾秒前、幾分鐘前、幾小時前、幾天前等格式 ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI