又一款js時鐘!transform實現(xiàn)時鐘效果
又來一個時鐘效果了,這個的實現(xiàn)不需要canvas,都是div、ul、li畫出的,好玩有真實。
哈哈~
需要的js才能實現(xiàn)到走動這個效果,但js的內(nèi)容不多,也不難。
主要是一個css里transform的使用的思路,transform里有很多變幻屬性,而普通的時鐘
在我心中就是個圓圓的東西,那么是不是可以旋轉(zhuǎn)這個屬性(rotate)實現(xiàn)了,它的刻度
使用旋轉(zhuǎn)且把旋轉(zhuǎn)點設置在圓心,那不就可以繞著圓心轉(zhuǎn)了嗎,而時針它們的底部不是和
圓心接觸的嗎,那么設置時針的底部為旋轉(zhuǎn)點不就OK了,大概的說了說思路。
代碼:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>transform</title> <style id="css"> #clock{ width: 200px; height: 200px; border: 2px solid #000; border-radius: 50%; margin: 100px auto 0; position: relative; } #clock ul{ width: 200px; height: 200px; position: relative; list-style: none; padding:0; margin: 0; } #clock ul li{ width: 2px; height: 10px; background: #000; transform-origin: center 100px; position: absolute; top: 0; left: 50%; } #clock ul li:nth-of-type(5n+1){ height: 20px; } #hour{ height: 40px; width: 4px; background: #00fefe; position: absolute; top: 60px; left: 99px; transform-origin:center bottom; } #min{ height: 60px; width: 3px; background: #001afe; position: absolute; top: 40px; left: 99px; transform-origin: center bottom; transform: rotate(15deg); } #sec{ height: 70px; width: 2px; background: #000; position: absolute; top: 30px; left: 99px; transform-origin:center bottom; } #dot{ width: 10px; height: 10px; position: absolute; left: 95px; top: 95px; background: #aaa; border-radius: 50%; } </style> </head> <body> <div id="clock"> <ul></ul> <div id="hour"></div> <div id="min"></div> <div id="sec"></div> <div id="dot"></div> </div> <script> var oCss=document.getElementById("css"); var oClock=document.getElementById("clock"); var oUl=oClock.getElementsByTagName("ul")[0]; var oHour=document.getElementById("hour"); var oMin=document.getElementById("min"); var oSec=document.getElementById("sec"); var strLi=""; var strCss=""; for(var i=0;i<60;i++){ strLi+="<li></li>"; } oUl.innerHTML=strLi; for(var i=0;i<60;i++){ strCss+='#clock ul li:nth-of-type('+(i+1)+'){transform:rotate('+i*6+'deg);}'; } oCss.innerHTML+=strCss; time(); setInterval(time,1000); function time(){ var date=new Date(); var h=date.getHours(); var m=date.getMinutes(); var s=date.getSeconds(); oHour.style.transform="rotate("+(h+m/60)*30+"deg)"; oMin.style.transform="rotate("+(m+s/60)*6+"deg)"; oSec.style.transform="rotate("+s*6+"deg)"; } </script> </body> </html>
使用標簽畫圖最主要的是定位,因為這樣我們就可以把弄到形狀的盒子放到你所想要的位置,內(nèi)部css樣式表是可以使用獲取元素的方式獲取的,這樣就可以 使用innerHTML為其添加樣式,且可以循環(huán)添加,還有因為刻度太多所以使用循環(huán)添加,這樣省時省力,至于剩下的就是定時器了,給定好1秒的時間,每1 秒執(zhí)行一次函數(shù),這樣它就是動起來了。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 基于css3新屬性transform及原生js實現(xiàn)鼠標拖動3d立方體旋轉(zhuǎn)
- 淺談javascript獲取元素transform參數(shù)
- 用js實現(xiàn)的模擬jquery的animate自定義動畫(2.5K)
- 圖片的左右移動,js動畫效果實現(xiàn)代碼
- 九種原生js動畫效果
- javascript判斷css3動畫結束 css3動畫結束的回調(diào)函數(shù)
- js動畫(animate)簡單引擎代碼示例
- JS判斷頁面加載狀態(tài)以及添加遮罩和緩沖動畫的代碼
- 實現(xiàn)動畫效果核心方式的js代碼
- JS實現(xiàn)超炫網(wǎng)頁煙花動畫效果的方法
- javascript與css3動畫結合使用小結
- js動畫效果打開層 關閉層
- JS實現(xiàn)動畫兼容性的transition和transform實例分析
相關文章
js showModalDialog參數(shù)的使用詳解
本篇文章主要是對js中showModalDialog參數(shù)的使用進行了詳細的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01JavaScript?Map?和?Object?的區(qū)別解析
在JavaScript中,Map 和 Object 看起來都是用鍵值對來存儲數(shù)據(jù),那么他們有什么不同呢,這篇文章主要介紹了JavaScript?Map?和?Object?的區(qū)別,需要的朋友可以參考下2022-08-08