很火的時鐘效果
主要用到原生態的 JS+CSS3。
具體不解釋了,看註釋
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
html{
background: #000;
color: #666;
font-size: 12px;
overflow:hidden;
}
*{
margin: 0;
padding: 0;
}
span{
display: block;
float: left;
}
.on{
color: #fff;
}
.wrapper{
width: 200px;
height: 200px;
position: absolute;
left:50%;
top:50%;
margin-top: -100px;
margin-left: -100px;
}
.wrapper .timebox{
position: absolute;
width: 200px;
height: 200px;
top: 0;
left:0;
border-radius: 100%;
transition: all 0.5s;
}
.timebox span{
transition: all 0.5s;
float: left;
}
.wrapper .timebox span{
position: absolute;
left:50%;
top:50%;
width: 40px;
height: 18px;
margin-top: -9px;
margin-left: -20px;
text-align: right;
}
</style>
</head>
<body>
<div id="wrapper">
<div class="timebox yuebox" id="yueBox"></div>
<div class="timebox riqiBox" id="riqiBox"></div>
<div class="timebox hourbox" id="hourbox"></div>
<div class="timebox minutebox" id="minutebox"></div>
<div class="timebox secondbox" id="secondbox"></div>
</div>
<script>
let wrapper = document.getElementById("wrapper");
let yueBox = document.getElementById("yueBox");
let riqiBox = document.getElementById("riqiBox");
let hourbox = document.getElementById("hourbox");
let minutebox = document.getElementById("minutebox");
let secondbox = document.getElementById("secondbox");
/*
* 找所有的東西標籤函式
* */
MT5實際操作
let findSiblings = function( tag ){
let parent = tag.parentNode;
let childs = parent.children;
let sb = [];
for(let i=0 ; i <= childs.length-1 ; i++){
if( childs[i]!==tag){
sb[sb.length] = childs[i];
}
}
return sb ;
};
/*
* 去掉所有兄弟的類
* */
let removeSiblingClass =function( tag ){
let sb = findSiblings( tag );
for(let i=0 ; i <= sb.length-1 ; i++){
sb[i].className = "";
}
};
/*
* 初始化月份函式
* */
let initMonth = function(){
for(let i=1; i<=12; i++){
let span = document.createElement("span");
span.innerHTML = i+"月";
yueBox.appendChild( span );
}
};
// 初始化日期
let initDate = function(){
for(let i=1; i<=31; i++){
let span = document.createElement("span");
span.innerHTML = i+"日";
riqiBox.appendChild( span );
}
};
// 初始化小時,分鐘,秒
let initHour = function(){
for(let i=0; i<=23; i++){
let h = i ;
let span = document.createElement("span");
if( h<10){
h="0"+h;
}
span.innerHTML = h +"點";
hourbox.appendChild( span );
}
};
let initMinute = function(){
for(let i=0; i<=59; i++){
let f = i ;
let span = document.createElement("span");
if( f<10){
f="0"+f;
}
span.innerHTML = f +"分";
minutebox.appendChild( span );
}
};
let initSecond = function(){
for(let i=0; i<=59; i++){
let miao = i ;
let span = document.createElement("span");
if( miao<10){
miao="0"+miao;
}
span.innerHTML = miao +"秒";
secondbox.appendChild( span );
}
};
// 時間文字樣式切換函式
let changeTime = function(tag){
tag.className = "on";
removeSiblingClass( tag );
};
/*
* 初始化日曆函式
* */
let initRili = function(){
initMonth(); // 初始化月份
initDate(); // 初始化日期
initHour(); // 小時
initMinute();
initSecond();
};
/*
* 展示當前時間
* 引數:mydate 時間物件
* */
let showNow = function( mydate ){
let yue = mydate.getMonth() ;
let riqi = mydate.getDate();
let hour = mydate.getHours() ;
let minute = mydate.getMinutes();
let second = mydate.getSeconds();
// 時間文字樣式切換函式
changeTime( yueBox.children[yue] );
changeTime( riqiBox.children[riqi-1] );
changeTime( hourbox.children[hour] );
changeTime( minutebox.children[minute] );
changeTime( secondbox.children[second] );
};
// 展示時間圓圈函式
// tag:目標
// num:數字數量
// dis:圓圈半徑
let textRound = function(tag,num,dis){
let span = tag.children ;
for(let i=0 ; i<=span.length-1; i++){
span[i].style.transform="rotate("+ (360/span.length)*i+"deg) translateX("+dis+"px)" ;
}
};
/*
* 旋轉指定“圓圈”指定度數
* */
let rotateTag = function(tag , deg){
tag.style.transform = "rotate("+deg+"deg)";
};
let main = function(){
initRili(); // 初始化日曆
setInterval(function(){
let mydate = new Date();
showNow( mydate ); // 展示當前時間
},1000);
// n秒後,擺出圓形
setTimeout(function(){
wrapper.className = "wrapper";
textRound(yueBox,12,40);
textRound(riqiBox,31,80);
textRound(hourbox,24,120);
textRound(minutebox,60,160);
textRound(secondbox,60,200);
setInterval(function(){
let mydate = new Date();
rotateTag( yueBox , -30*mydate.getMonth());
rotateTag( riqiBox , -360/31*(mydate.getDate()-1) );
rotateTag( hourbox , -360/24*mydate.getHours());
rotateTag( minutebox , -6*mydate.getMinutes());
rotateTag( secondbox , -6*mydate.getSeconds());
},1000)
},6000)
};
main();
</script>
</body>
</html>
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69946337/viewspace-2682291/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- canvas圓形時鐘效果Canvas
- canvas動態時鐘效果Canvas
- 聊聊最近很火的eBPFeBPF
- 最近很火的區塊鏈區塊鏈
- OneClock的翻頁時鐘效果是如何實現的
- Swift如何純程式碼實現時鐘效果Swift
- CSS3圓形時鐘效果程式碼CSSS3
- 哋它亢:最近很火的網路詞
- [精選]php 如何使用最近很火的ChatGPTPHPChatGPT
- 用Python實現一個實時運動的大掛鐘效果Python
- 網上很火的ai繪畫是什麼軟體?好奇試了一下,效果真驚呆了!AI
- 最近很火的低程式碼到底是什麼?
- 實時時鐘、系統時鐘和主機伺服器時鐘的區別伺服器
- SVG圓形鐘錶效果SVG
- 運動的時鐘
- 花了1塊錢體驗一把最近很火的ChatGPTChatGPT
- 今年很火的五大Python框架,你還不知道?Python框架
- 最近很火的低程式碼開發究竟是什麼?
- 系統時鐘與硬體時鐘
- 小時候的螢火蟲
- Python雖然很火,為啥找工作這麼難?Python
- 為什麼《Kenshi》在兩年之後依然很火?
- 行走的時鐘動畫動畫
- Clock——時鐘
- 你選擇圖資料庫的原因只是因為它很火嗎?資料庫
- 5分鐘學會Vue動畫效果Vue動畫
- canvas原型鐘錶效果程式碼例項Canvas原型
- 有個VSCode theme很火很美,容易讓人沉迷程式碼VSCode
- 超火的 ChatGPT,APISpace 讓你一分鐘免費接入ChatGPTAPI
- 3分鐘讀懂火熱的人工智慧!人工智慧
- 網頁時鐘網頁
- 現在很火的合約跟單模式是什麼?詳細介紹模式
- 為什麼說現在很火的區塊鏈技術“老笨慢”?區塊鏈
- JavaScript動態圓形鐘錶效果詳解JavaScript
- canvas繪製圓盤走動鐘錶效果Canvas
- CSS動畫篇之炫酷時鐘之時鐘牆CSS動畫
- 「分散式技術專題」時鐘系列一:事件的因果和邏輯時鐘分散式事件
- ntp導致的時鐘回撥