多個js毫秒倒計時同時進行效果
本文實例講解js毫秒倒計時同時進行效果的代碼,分享給大家供大家參考,具體內(nèi)容如下
實現(xiàn)功能:調(diào)用一個函數(shù),傳入html元素的id,和一個截止時間(unix時間戳),在該html元素中打印出到當前到截止時間為止的倒計時,精確到毫秒;
效果圖如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
<title></title>
<style>
div{
width: 100%;
height: 50px;
margin-bottom: 5px;
background: yellowgreen;
}
</style>
</head>
<body>
<h2>毫秒的倒計時</h2>
<div id="timer1"></div>
<div id="timer2"></div>
<div id="timer3"></div>
<div id="timer4"></div>
<script>
var addTimer = function(){
var list = [],
interval;
return function(id,timeStamp){
if(!interval){
interval = setInterval(go,1);
}
list.push({ele:document.getElementById(id),time:timeStamp});
}
function go() {
for (var i = 0; i < list.length; i++) {
list[i].ele.innerHTML = changeTimeStamp(list[i].time);
if (!list[i].time)
list.splice(i--, 1);
}
}
//傳入unix時間戳,得到倒計時
function changeTimeStamp(timeStamp){
var distancetime = new Date(timeStamp*1000).getTime() - new Date().getTime();
if(distancetime > 0){
//如果大于0.說明尚未到達截止時間
var ms = Math.floor(distancetime%1000);
var sec = Math.floor(distancetime/1000%60);
var min = Math.floor(distancetime/1000/60%60);
var hour =Math.floor(distancetime/1000/60/60%24);
if(ms<100){
ms = "0"+ ms;
}
if(sec<10){
sec = "0"+ sec;
}
if(min<10){
min = "0"+ min;
}
if(hour<10){
hour = "0"+ hour;
}
return hour + ":" +min + ":" +sec + ":" +ms;
}else{
//若否,就是已經(jīng)到截止時間了
return "已截止!"
}
}
}();
addTimer("timer1",1451923200);//1月5日00點,unix時間戳自己去百度一下,就有的
addTimer("timer2",1451926800);//1月5日01點
addTimer("timer3",1451930400);//1月5日02點
addTimer("timer4",1452020400);//1月6日03點
</script>
</body>
</html>
如何使用這個函數(shù)?
addTimer("#id",時間戳int);
PS:
其實這個函數(shù)有一個小小的問題:就是并不會顯示截止天數(shù);因為老板表示我們的倒計時時間最多也就幾個小時,所以在判斷倒計時的小時和天數(shù)上,我也就懶得寫那么多了。所以如果傳入的時間戳距今超過了1天。那么你會看到如此結果:02:11:32:874~~只剩2個小時了!明顯不對是不是?
so,有2個方案這里:
方法1:把var hour =Math.floor(distancetime/1000/60/60%24);改成var hour =Math.floor(distancetime/1000/60/60);
如果截止時間距今超出一天了,小時位置會顯示大于24的數(shù)字;比如:36:45:22:888
方法2:你自己再寫一個計算天數(shù)的變量;
更多關于倒計時的文章請查看專題:《倒計時功能》
更多JavaScript時鐘特效點擊查看:JavaScript時鐘特效專題
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。
相關文章
細說JavaScript中的this指向與綁定規(guī)則
本文主要詳細介紹了JavaScript中的this指向與綁定規(guī)則,默認綁定,隱式綁定,顯示綁定,new綁定這四個規(guī)則,文中有相關的代碼示例供大家參考,感興趣的同學可以閱讀下2023-05-05
javascript 動態(tài)生成css代碼的兩種方法
這篇文章主要介紹了javascript 動態(tài)生成css代碼的兩種方法,有時候我們需要利用js來動態(tài)生成頁面上style標簽中的css代碼,下面就給大家介紹兩種方法,需要的朋友可以參考下2017-03-03
window.name代替cookie的實現(xiàn)代碼
window.name代替cookie的實現(xiàn)代碼,需要的朋友可以參考下。2010-11-11
在js中判斷checkboxlist(.net控件客戶端id)是否有選中
添加或修改內(nèi)容時,需要對關鍵數(shù)據(jù)進行判空處理,checkboxlist是否有選擇項如何使用js判斷實現(xiàn),接下來為大家詳細介紹下實現(xiàn)方法,感興趣的朋友可以參考下哈2013-04-04
JavaScript實現(xiàn)淘寶購物件數(shù)選擇

