溫馨提示×

溫馨提示×

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

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

js如何實現(xiàn)頁面多個日期時間倒計時效果

發(fā)布時間:2021-04-19 14:06:09 來源:億速云 閱讀:264 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了js如何實現(xiàn)頁面多個日期時間倒計時效果,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

js的日期倒計時在日常項目中還是比較常用的,活動、拼團功能最為常見,先分析最要是處理好日期函數(shù),然后一個頁面上有多個倒計時情況下的方法;

來,先看下 拼多多 的拼單倒計時的效果:

js如何實現(xiàn)頁面多個日期時間倒計時效果

那么,先上個代碼吧:

案例效果:

js如何實現(xiàn)頁面多個日期時間倒計時效果

<style>
  .mytime{ line-height: 40px; width: 300px; margin: 0 auto;}
 </style>

<div class="mytime jsTime" data-time="2019-04-01 16:58:00">時間1</div>
<div class="mytime jsTime" data-time="2019-04-04 18:00:02">時間2</div>
<div class="mytime jsTime" data-time="2019-04-05 19:01:31">時間3</div>
<div class="mytime jsTime" data-time="2019-04-06 05:05:15">時間4</div>
<div class="mytime jsTime" data-time="2019-04-07 09:01:43">時間5</div>
<hr>
<div class="mytime jsTime2" data-time="2019-04-08 16:30:05">時間1</div>
<div class="mytime jsTime2" data-time="2019-04-09 14:01:22">時間2</div>
<div class="mytime jsTime2" data-time="2019-04-10 18:06:25">時間3</div>
<div class="mytime jsTime2" data-time="2019-04-11 22:07:19">時間4</div>
<div class="mytime jsTime2" data-time="2019-04-12 23:12:38">時間5</div>
<!-- 方法1 -->
<script>
 const countdown = {
  domList : document.querySelectorAll('.jsTime'),
  formatNumber(n){
   // return n.toString().padStart(2, '0'); // 用padStart方法要注意兼容問題
   n = n.toString();
   return n[1] ? n : '0' + n;
  },
  setTime(dom){
   //獲取設置的時間 如:2019-3-28 14:00:00 ios系統(tǒng)得加正則.replace(/\-/g, '/');
   const leftTime = new Date(dom.getAttribute('data-time').replace(/\-/g, '/')) - new Date();
   if (leftTime >= 0) {
    const d = Math.floor(leftTime / 1000 / 60 / 60 / 24);
    const h = Math.floor(leftTime / 1000 / 60 / 60 % 24);
    const m = Math.floor(leftTime / 1000 / 60 % 60);
    const s = Math.floor(leftTime / 1000 % 60);
    dom.innerHTML = `剩余${ d > 0 ? d + '天' : '' }${ [h, m, s].map(this.formatNumber).join(':') }`;
   } else {
    clearInterval(dom.$timer);
    dom.innerHTML = '拼團已結束';
   }
  },
  start(){
   this.domList.forEach((dom) => {
    this.setTime(dom);
    dom.$timer = setInterval(() => {
     this.setTime(dom);
    }, 1e3);
   });
  },
 };
 countdown.start();
</script>
<!-- 方法2 -->
<script>
 //時間格式處理
 const formatNumber = n => {
 n = n.toString();
 return n[1] ? n : '0' + n;
 };
 //團購倒計時
 const teamCountTime = (obj) => {
 var timer = null;
 function fn(){
  //獲取設置的時間 如:2019-3-28 14:00:00 ios系統(tǒng)得加正則.replace(/\-/g, '/');
  var setTime = obj.getAttribute('data-time').replace(/\-/g, '/');
  //獲取當前時間
  var date = new Date(),
   now  = date.getTime(),
   endDate = new Date(setTime),
   end  = endDate.getTime();
  //時間差
  var leftTime = end - now;
  //d,h,m,s 天時分秒
  var d, h,m,s;
  var otime = '';
  if (leftTime >= 0) {
  d = Math.floor(leftTime / 1000 / 60 / 60 / 24);
  h = Math.floor(leftTime / 1000 / 60 / 60 % 24);
  m = Math.floor(leftTime / 1000 / 60 % 60);
  s = Math.floor(leftTime / 1000 % 60);
  if (d <= 0) {
   otime = [h, m, s].map(formatNumber).join(':');
  } else {
   otime = d + '天' + [h, m, s].map(formatNumber).join(':');
  }
  obj.innerHTML = '剩余' + otime;
  //
  timer = setTimeout(fn, 1e3);
  } else {
  clearTimeout(timer);
  obj.innerHTML = '拼團已結束';
  }
 }
 fn();
 };
 let jsTimes = document.querySelectorAll('.jsTime2');
 jsTimes.forEach((obj) => {
 teamCountTime(obj);
 });
</script>

感謝你能夠認真閱讀完這篇文章,希望小編分享的“js如何實現(xiàn)頁面多個日期時間倒計時效果”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業(yè)資訊頻道,更多相關知識等著你來學習!

向AI問一下細節(jié)

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

js
AI