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

那么,先上個代碼吧:
案例效果:

<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){
//獲取設(shè)置的時間 如: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 = '拼團已結(jié)束';
}
},
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(){
//獲取設(shè)置的時間 如: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 = '拼團已結(jié)束';
}
}
fn();
};
let jsTimes = document.querySelectorAll('.jsTime2');
jsTimes.forEach((obj) => {
teamCountTime(obj);
});
</script>
具體代碼可訪問本人github
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript實現(xiàn)的商品搶購倒計時功能示例
這篇文章主要介紹了JavaScript實現(xiàn)的商品搶購倒計時功能,可實現(xiàn)分秒級別的實時顯示倒計時效果,涉及js日期時間計算與頁面元素動態(tài)操作相關(guān)技巧,需要的朋友可以參考下2017-04-04
JavaScript ECMA-262-3 深入解析(二):變量對象實例詳解
這篇文章主要介紹了JavaScript ECMA-262-3變量對象,結(jié)合實例形式詳細分析了JavaScript ECMA變量對象相關(guān)概念、原理、用法及操作注意事項,需要的朋友可以參考下2020-04-04
JS實現(xiàn)統(tǒng)計字符串中字符出現(xiàn)個數(shù)及最大個數(shù)功能示例
這篇文章主要介紹了JS實現(xiàn)統(tǒng)計字符串中字符出現(xiàn)個數(shù)及最大個數(shù)功能,結(jié)合實例形式分析了javascript字符串遍歷、統(tǒng)計相關(guān)操作技巧,需要的朋友可以參考下2018-06-06
JavaScript實現(xiàn)獲取圖片文件真實格式的示例代碼
每種格式的圖片,都有自己特有的優(yōu)缺點以及數(shù)據(jù)結(jié)構(gòu),本篇博文的目的就是基于不同格式的圖像二進制數(shù)據(jù),獲取到圖片的真實格式,感興趣的可以了解一下2023-02-02
詳解js模板引擎art template數(shù)組渲染的方法
art-template 是一個簡約、超快的模板引擎。這篇文章主要介紹了詳解js模板引擎art template數(shù)組渲染的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10
在html文本框中顯示提示效果,以方便用戶的輸入,比如在輸入姓名時,會自動提示 姓名長度最多16個字符,是不是很酷哦??靵砜纯窗?/div> 2014-06-06
JavaScript實現(xiàn)點擊文本自動定位到下拉框選中操作
這篇文章主要介紹了JavaScript實現(xiàn)點擊文本自動定位到下拉框選中操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06最新評論

