日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

js+css3實現(xiàn)簡單時鐘特效

瀏覽:409日期:2024-04-20 15:32:52

本文實例為大家分享了js+css3實現(xiàn)簡單時鐘的具體代碼,供大家參考,具體內(nèi)容如下

1.實現(xiàn)了時鐘的特效,可以轉(zhuǎn)動,時間準確,畫面美觀大氣;2.用到了css3的transform: rotate,transform-origin:,偽元素,border-radius,定位,z-index等等

效果如圖:

js+css3實現(xiàn)簡單時鐘特效

代碼如下:

<!DOCTYPE html><html> <head> <meta charset='UTF-8'> <title>CSS3時鐘特效</title> <link rel='shortcut icon' type='image/x-icon' href='http://www.b3g6.com/bcjs/img/an.ico' /> <style> /*表盤邊框*/ .clock { /* 設(shè)置大小 */ width: 400px; height: 400px; position: relative; margin: 40px auto; /*上邊距*/ border-radius: 50%; /*圓形*/ box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.5); /*表盤陰影*/ background: #F5DEB3; border: 10px solid #FFFF00; } /*畫刻度的面板*/ .box { width: 100%; height: 100%; position: absolute; top: 0; left: 0; } /*用來裝刻度和數(shù)字的div*/ .box div { width: 0px; height: 200px; position: absolute; left: 200px; /*旋轉(zhuǎn)*/ transform: rotate(0deg); /*設(shè)置基點為右下角*/ transform-origin: bottom right; background: rgba(255, 0, 0, 0.5); } /*數(shù)字*/ .box div i { float: left; margin-top: 20px; margin-left: -10px; font-style: normal; width: 20px; text-align: center; font-style: 18px; } /*小刻度*/ .box div::after { content: ''; position: absolute; background: #484848; width: 2px; height: 10px; left: -1px; } /*大刻度*/ .box div.five::after { position: absolute; content: ''; width: 4px; height: 20px; left: -2px; top: 0; background: #484848; border-radius: 0 0 2px 2px; } /*秒針樣式*/ .second { width: 1px; height: 200px; background: red; position: absolute; left: 200px; /*距離表盤寬度一半*/ margin-top: 30px; z-index: 10; transform: rotate(0deg); transform-origin: center 170px; /*定位旋轉(zhuǎn)位置*/ } /*圓心樣式*/ .second::after { content: ''; position: absolute; width: 20px; height: 20px; background: red; border-radius: 50%; bottom: 20px; left: -10px; } /*分針樣式*/ .minute { width: 2px; height: 140px; background: #8b8b8d; position: absolute; left: 199px; margin-top: 60px; z-index: 9; transform-origin: center bottom; transform: rotate(12deg); animation: minute 60s linear infinite; } /*時針樣式*/ .hour { width: 6px; height: 100px; background: #333; position: absolute; left: 197px; margin-top: 100px; z-index: 8; border-radius: 3px; transform: rotate(2deg); transform-origin: center bottom; animation: minute 60s linear infinite; } </style> </head> <body> <div class='clock'> <div class='box'></div> <div class='second'></div> <div class='minute'></div> <div class='hour'></div> </div> <script> var box = document.getElementsByClassName('box')[0]; var ssObj = document.getElementsByClassName('second')[0]; var mmObj = document.getElementsByClassName('minute')[0]; var hhObj = document.getElementsByClassName('hour')[0]; /*獲取當前時間*/ var date = new Date(); var hh = date.getHours(); var mm = date.getMinutes(); var ss = date.getSeconds(); /*計算頁面指針加載時的角度*/ hhDeg = 360 * (hh % 12) / 12; mmDeg = 360 * mm / 60; ssDeg = 360 * ss / 60; hhObj.style.transform = 'rotate(' + hhDeg + 'deg)'; mmObj.style.transform = 'rotate(' + mmDeg + 'deg)'; ssObj.style.transform = 'rotate(' + ssDeg + 'deg)'; // 定義初始刻度的度數(shù) var Deg = 0; /*畫刻度*/ for (var i = 0; i < 60; i++) { var div1 = document.createElement('div'); //創(chuàng)建一個div var hourNum = i / 5; //當為5時 if (hourNum == 0) hourNum = 12; if (i % 5 == 0) { //大刻度 div1.className = 'five'; div1.innerHTML = '<i>' + hourNum + '</i>' } div1.style.transform = 'rotate(' + Deg + 'deg)'; box.appendChild(div1); Deg += 6;// 每兩個刻度之間是6度 } /*指針轉(zhuǎn)動的函數(shù)*/ function drawSS() { // 秒針的度數(shù) ssDeg = 360 * ss / 60; // 分針的度數(shù) mmDeg1 = 360 * mm / 60; // 時針的度數(shù) hhDeg1 = 360 * (hh % 12) / 12; // 分針每秒走的位置 mmDeg = mmDeg1 + (6 * ss / 60); // 時針每分鐘走的位置 hhDeg = hhDeg1 + (30 * mm / 60); hhObj.style.transform = 'rotate(' + hhDeg + 'deg)'; mmObj.style.transform = 'rotate(' + mmDeg + 'deg)'; ssObj.style.transform = 'rotate(' + ssDeg + 'deg)'; ss += 1; if (ss > 60) { ss = 1; mm += 1; } if (mm == 60) { mm = 0; hh += 1; } setTimeout(function() { drawSS(); }, 1000); } drawSS(); </script> </body></html>

精簡版:

<!DOCTYPE html><html> <head> <meta charset='UTF-8'> <title>CSS3時鐘特效</title> <link rel='shortcut icon' type='image/x-icon' href='http://www.b3g6.com/bcjs/img/an.ico' /> <style> /*表盤邊框*/ .clock { /* 設(shè)置大小 */ width: 400px; height: 400px; position: relative; margin: 40px auto; /*上邊距*/ border-radius: 50%; /*圓形*/ box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.5); /*表盤陰影*/ background: #F5DEB3; border: 10px solid #FFFF00; } /*畫刻度的面板*/ .box { width: 100%; height: 100%; position: absolute; top: 0; left: 0; } /*用來裝刻度的div*/ .box div { width: 0px; height: 200px; position: absolute; left: 200px; /*旋轉(zhuǎn)*/ transform: rotate(0deg); /*設(shè)置基點為右下角*/ transform-origin: bottom right; background: rgba(255, 0, 0, 0.5); } /*小刻度*/ .box div:after { content: ''; position: absolute; background: #484848; width: 2px; height: 10px; left: -1px; } /*大刻度*/ .box div.five:after { position: absolute; content: ''; width: 4px; height: 20px; left: -2px; top: 0; background: #484848; border-radius: 0 0 2px 2px; } /*秒針樣式*/ .second { width: 1px; height: 200px; background: red; position: absolute; left: 200px; /*距離表盤寬度一半*/ margin-top: 30px; z-index: 10; transform: rotate(0deg); transform-origin: center 170px; /*定位旋轉(zhuǎn)位置*/ } /*圓心樣式*/ .second:after { content: ''; position: absolute; width: 20px; height: 20px; background: red; border-radius: 50%; bottom: 20px; left: -10px; } /*分針樣式*/ .minute { width: 2px; height: 140px; background: #8b8b8d; position: absolute; left: 199px; margin-top: 60px; z-index: 9; transform-origin: center bottom; transform: rotate(12deg); } /*時針樣式*/ .hour { width: 6px; height: 100px; background: #333; position: absolute; left: 197px; margin-top: 100px; z-index: 8; border-radius: 3px; transform: rotate(2deg); transform-origin: center bottom; } </style> </head> <body> <div class='clock'> <div class='box'></div> <div class='second'></div> <div class='minute'></div> <div class='hour'></div> </div> <script> var box = document.getElementsByClassName('box')[0]; var ssObj = document.getElementsByClassName('second')[0]; var mmObj = document.getElementsByClassName('minute')[0]; var hhObj = document.getElementsByClassName('hour')[0]; /*獲取當前時間*/ var date = new Date(); var hh = date.getHours(); var mm = date.getMinutes(); var ss = date.getSeconds(); /*計算頁面指針加載時的角度*/ drawSS(); // 定義初始刻度的度數(shù) var Deg = 0; /*畫刻度*/ for (var i = 0; i < 60; i++) { var div1 = document.createElement('div'); //創(chuàng)建一個div //當為5時 if (i % 5 == 0) { //大刻度 div1.className = 'five'; } div1.style.transform = 'rotate(' + Deg + 'deg)'; box.appendChild(div1); Deg += 6;// 每兩個刻度之間是6度 } /*指針轉(zhuǎn)動的函數(shù)*/ function drawSS() { // 秒針的度數(shù) ssDeg = 360 * ss / 60; // 分針的度數(shù) mmDeg = 360 * mm / 60 + (6 * ss / 60); // 時針的度數(shù) hhDeg = 360 * (hh % 12) / 12 + (30 * mm / 60); // 旋轉(zhuǎn) hhObj.style.transform = 'rotate(' + hhDeg + 'deg)'; mmObj.style.transform = 'rotate(' + mmDeg + 'deg)'; ssObj.style.transform = 'rotate(' + ssDeg + 'deg)'; ss += 1; // 每秒鐘調(diào)用一次 setTimeout(function() { drawSS(); }, 1000); } </script> </body></html>

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品极品| 婷婷亚洲五月| 91精品国产自产观看在线| 国产精品一站二站| 国产66精品| 国产视频一区三区| 亚洲精品韩国| 国产aⅴ精品一区二区三区久久| 免费毛片在线不卡| 国产精品麻豆成人av电影艾秋| 亚洲成人二区| 亚洲精品无播放器在线播放| 精品国产第一福利网站| 视频一区欧美精品| 麻豆中文一区二区| 免费视频久久| 精品国产三区在线| 一本一道久久a久久| 欧美国产一级| 日欧美一区二区| 久久在线电影| 亚洲精品伊人| 久久久久99| 国产精品一区二区av日韩在线| 久久国产主播| 国产高清日韩| 亚洲香蕉久久| 少妇久久久久| 麻豆国产欧美日韩综合精品二区| 国产精品丝袜xxxxxxx| 精品资源在线| 亚洲精品欧美| av一区二区高清| 欧美黄色精品| 三级久久三级久久久| 久久精品在线| 国产精品扒开腿做爽爽爽软件| 伊人久久成人| 国产精品yjizz视频网| 伊人久久亚洲| 国产在线欧美| 成人午夜网址| 国产精品香蕉| 在线国产日韩| 黄色亚洲精品| 蜜桃精品在线| 精品91福利视频| 欧美片第1页综合| 亚洲欧美高清| 国产91精品对白在线播放| 精品福利久久久| 久久国产精品亚洲77777| 日本精品黄色| 免费一级欧美片在线观看网站| 中文字幕亚洲在线观看| 欧美日韩日本国产亚洲在线| 免费高潮视频95在线观看网站| 国产精久久一区二区| 亚洲精品影视| 免费在线看一区| 国产日韩综合| 午夜国产精品视频| 久久久影院免费| av综合电影网站| 国产suv精品一区| 久久精品国产在热久久| 亚洲精品免费观看| 美女国产一区| 噜噜噜久久亚洲精品国产品小说| 欧美精选一区二区三区| 欧美日韩一二三四| 成人久久久久| 久久久久亚洲| 久久在线视频免费观看| 成人久久久久| 成人免费电影网址| 久久在线视频免费观看| 日本精品不卡| 色爱综合av| www成人在线视频| 欧美综合另类| 国产在线不卡| 视频小说一区二区| 久久久亚洲一区| 精精国产xxxx视频在线播放| 久久久久久自在自线| 久久99蜜桃| 久久精品国产精品亚洲毛片| 精品视频久久| 蜜桃精品在线| 欧美日韩精品一区二区视频| 国产精品任我爽爆在线播放 | av综合电影网站| 亚洲欧美日韩一区在线观看| 伊人精品视频| 中文字幕一区二区精品区| 免费国产自线拍一欧美视频| 久久亚洲风情| 亚洲aa在线| 欧美日本不卡高清| 精品久久中文| 欧美日韩一二三四| 国产午夜精品一区二区三区欧美| 鲁大师成人一区二区三区| 亚洲精选成人| 国产欧美久久一区二区三区| 国产精品jk白丝蜜臀av小说| 精品久久久网| 麻豆一区二区三| 热三久草你在线| 中文久久精品| 日本少妇一区二区| 美女视频网站久久| 日韩中文视频| 丝袜诱惑制服诱惑色一区在线观看| 日本一区免费网站| 精品网站999| 激情久久久久久久| 免费在线视频一区| 综合一区二区三区| 麻豆久久久久久| 亚洲午夜黄色| 伊人久久亚洲| 日韩av一二三| 国产一区二区三区不卡av| 欧美亚洲激情| 日韩在线观看中文字幕| 国产一区二区三区视频在线| 激情婷婷综合| 青青国产精品| 999精品色在线播放| 色狠狠一区二区三区| 国产a亚洲精品| 最新日韩欧美| 国产精品久久久一区二区| 久久久久午夜电影| 日韩av电影一区| 久久在线视频免费观看| 日韩在线观看一区二区| 欧美aⅴ一区二区三区视频| 欧美中文一区二区| 青草av.久久免费一区| 久久久一本精品| 亚洲精品进入| 日韩在线观看不卡| 欧美日本二区| 亚洲欧洲日本mm| 久久只有精品| 久久www成人_看片免费不卡| 欧美激情福利| 久久国产88| 成人美女视频| 欧美日韩一区二区国产| 久久黄色影院| 国产乱码精品一区二区亚洲| 国产尤物精品| 精品亚洲成人| 亚洲人成毛片在线播放女女| 日本精品不卡| 国产精品宾馆| 亚洲视频二区| 久久在线视频免费观看| 麻豆久久久久久| 亚洲人妖在线| 亚洲一级二级| 日产精品一区二区| 亚州欧美在线| jiujiure精品视频播放| 欧美精品97| 亚洲丝袜美腿一区| 欧美~级网站不卡| 麻豆一区二区在线| 日韩二区三区在线观看| 欧美日韩精品一本二本三本| sm久久捆绑调教精品一区| 日韩精品成人| 国产亚洲精品久久久久婷婷瑜伽| 福利精品在线| 日本成人手机在线| 鲁大师成人一区二区三区 | 激情视频网站在线播放色| 日韩一区精品| 老鸭窝亚洲一区二区三区| 91精品国产福利在线观看麻豆| 老司机精品视频在线播放| 日本欧美一区二区| 国产免费成人| 国产综合色产| 日韩欧美自拍| 色乱码一区二区三区网站| 国产精品嫩草影院在线看| 亚洲精品大片| 丝袜美腿高跟呻吟高潮一区| 亚洲手机视频| 丝袜美腿诱惑一区二区三区| 色婷婷综合网| 国产精品色在线网站| 日韩高清一区在线| 亚洲一区二区日韩| 视频精品一区二区|