原生JS實(shí)現(xiàn)數(shù)碼表特效
更新時(shí)間:2021年10月15日 08:39:23 作者:aiguangyuan
這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)數(shù)碼表特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文分享一個(gè)用原生JS實(shí)現(xiàn)的數(shù)碼時(shí)鐘特效,效果如下:

上面的數(shù)字是用的圖片生成的,共10張圖片如下:

![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
![]()
實(shí)現(xiàn)代碼如下,歡迎大家復(fù)制粘貼。
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>原生JS實(shí)現(xiàn)數(shù)碼表特效</title>
<style>
body {
background: blue;
color: white;
font-size: 30px;
}
#div1 {
width: 220px;
height: 36px;
position: fixed;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
border: 1px #FFF solid;
}
#div1 img {
width: 25px;
height: 36px;
position: relative;
}
</style>
<script>
window.onload = function () {
//獲取所有的圖片
var aImg = document.getElementsByTagName('img');
//獲取本地進(jìn)間對象
var oDate = new Date();
//小時(shí)+分鐘+秒
var prevStr = toZero(oDate.getHours()) +
toZero(oDate.getMinutes()) +
toZero(oDate.getSeconds());
//聲明下一次時(shí)間的字符串變量
var nextStr = '';
//同一時(shí)間變化的不僅僅秒數(shù),有可能是多位數(shù),建數(shù)組存儲(chǔ)
var arr = [];
var timer = null;
//第i個(gè)img圖片的src地址為img下當(dāng)前時(shí)間第i位數(shù)所對應(yīng)的圖片名稱
//104604=>通過charAt(i)分別獲得1到6位的字符,即1,0,4,6,0,4
for (var i = 0; i < aImg.length; i++) {
aImg[i].src = 'images/' + prevStr.charAt(i) + '.png';
};
//設(shè)置定時(shí)器,1秒鐘執(zhí)行1次toChange方法
setInterval(toChange, 1000);
//獲取下一次的時(shí)間
function toChange() {
//獲取本地進(jìn)間對象
var oDate = new Date();
//小時(shí)+分鐘+秒
nextStr = toZero(oDate.getHours()) +
toZero(oDate.getMinutes()) +
toZero(oDate.getSeconds());
//將上一次的時(shí)間和下一次的時(shí)間做對比
toCom(prevStr, nextStr);
//把下1秒的時(shí)間賦給當(dāng)前,不斷變化
prevStr = nextStr;
};
//上一次的時(shí)間和下一次的時(shí)間對比函數(shù)
function toCom(str1, str2) {
//比較之前,將之前的清空,重新賦值
arr = [];
//遍歷第1次時(shí)間的每1位數(shù)字
for (var i = 0; i < str1.length; i++) {
//如果有1位字符與下一次時(shí)間對應(yīng)的字符不同
if (str1.charAt(i) != str2.charAt(i)) {
//將它壓入數(shù)組中
arr.push(i);
}
}
//執(zhí)行圖片翻轉(zhuǎn)
startMove();
};
//圖片翻轉(zhuǎn)函數(shù)
function startMove() {
//圖片高度36px,設(shè)定第次減少-4px
var iSpeed = -4;
//設(shè)定定時(shí)器
timer = setInterval(function () {
//循環(huán)遍歷數(shù)組中上一次時(shí)間和下一次時(shí)間發(fā)生變化的字符串
for (var i = 0; i < arr.length; i++) {
//如果數(shù)組中不同的字符所對應(yīng)名稱的圖片高度等于0
if (aImg[arr[i]].offsetHeight == 0) {
//將變化速度設(shè)為增加4px
iSpeed = 4;
//不同的字符所對應(yīng)名稱的圖片位置等于img里下一次時(shí)間第i位數(shù)所對應(yīng)的圖片名稱
//i代表兩次時(shí)間變化所在的數(shù)字位數(shù),arr[i]得出具體數(shù)字
aImg[arr[i]].src = 'images/' + nextStr.charAt(arr[i]) + '.png';
}
//數(shù)組中不同的字符所對應(yīng)名稱的圖片的高度等于它內(nèi)容高度每次減4px
//注意style.height和offsetHeight的高度
aImg[arr[i]].style.height = aImg[arr[i]].offsetHeight + iSpeed + 'px';
//數(shù)組中不同的字符所對應(yīng)名稱的圖片的top值等于它內(nèi)容高度1半減18px
//以保證每次變化圖片都可以居中顯示
aImg[arr[i]].style.top = aImg[arr[i]].offsetHeight / 2 - 18 + 'px';
//當(dāng)圖片的高度達(dá)到最大高度36px時(shí)
if (aImg[arr[i]].offsetHeight == 36) {
//清除定時(shí)器
clearInterval(timer);
}
}
}, 10);
};
//獲取本地時(shí)間個(gè)位數(shù)不滿10,而十位數(shù)為0是沒有的,此處封裝函數(shù)補(bǔ)全
function toZero(num) {
if (num < 10) {
return '0' + num;
} else {
return '' + num;
}
}
};
</script>
</head>
<body>
<div id="div1">
<img src="images/0.png" />
<img src="images/0.png" />:
<img src="images/0.png" />
<img src="images/0.png" />:
<img src="images/0.png" />
<img src="images/0.png" />
</div>
</body>
</html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何正確使用javascript 來進(jìn)行我們的程序開發(fā)
Javascript 正確使用方法,下面為大家介紹的是一個(gè)關(guān)于如何正確使用javascript 來進(jìn)行我們的程序開發(fā),需要的朋友可以參考下2014-06-06
JS如何實(shí)現(xiàn)頁面截屏功能實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于JS如何實(shí)現(xiàn)頁面截屏功能的相關(guān)資料,文中主要利用了html2canvas和canvas繪制兩個(gè)方法來實(shí)現(xiàn),需要的朋友可以參考下2021-06-06
JS實(shí)現(xiàn)懸浮球只在一側(cè)滑動(dòng)并且是橫屏狀態(tài)下
這篇文章主要介紹了JS實(shí)現(xiàn)懸浮球只在一側(cè)滑動(dòng) 并且是橫屏狀態(tài)下,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
微信小程序藍(lán)牙連接小票打印機(jī)實(shí)例代碼詳解
這篇文章主要介紹了微信小程序藍(lán)牙連接小票打印機(jī)實(shí)例代碼,代碼簡單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06
關(guān)于JavaScript的內(nèi)存與性能問題解決匯總
這篇文章主要介紹了關(guān)于JavaScript的內(nèi)存與性能問題解決匯總,在JavaScript中,頁面中事件處理程序的數(shù)量與頁面整體性能直接相關(guān),原因有很多,下面就一起來看看具體的總結(jié)吧2022-04-04

