欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

javascript和CSS3實現(xiàn)時鐘效果

本文講述了抖音上很火的時鐘效果是怎么實現(xiàn)的,主要用到原生態(tài)的 JS+CSS3,希望大家可以交流學(xué)習(xí)一下。

成都創(chuàng)新互聯(lián)主要從事成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)共和,10年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18980820575

javascript和CSS3實現(xiàn)時鐘效果

具體不解釋了,看注釋:

<!DOCTYPE html>
<html lang="en">
<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>

<p id="wrapper">
    <p class="timebox yuebox" id="yueBox"></p>
    <p class="timebox riqiBox" id="riqiBox"></p>
    <p class="timebox hourbox" id="hourbox"></p>
    <p class="timebox minutebox" id="minutebox"></p>
    <p class="timebox secondbox" id="secondbox"></p>
</p>


<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");

    /*
    * 找所有的東西標簽函數(shù)
    * */
    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 = "";
        }
    };

    /*
    * 初始化月份函數(shù)
    * */
    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 );
        }
    };

    // 時間文字樣式切換函數(shù)
    let changeTime = function(tag){
        tag.className = "on";
        removeSiblingClass( tag );
    };

    /*
    * 初始化日歷函數(shù)
    * */
    let initRili = function(){
        initMonth(); // 初始化月份
        initDate(); // 初始化日期
        initHour(); // 小時
        initMinute();
        initSecond();
    };

    /*
    * 展示當(dāng)前時間
    * 參數(shù):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();
        // 時間文字樣式切換函數(shù)
        changeTime( yueBox.children[yue] );
        changeTime( riqiBox.children[riqi-1] );
        changeTime( hourbox.children[hour] );
        changeTime( minutebox.children[minute] );
        changeTime( secondbox.children[second] );

    };

    // 展示時間圓圈函數(shù)
    // tag:目標
    // num:數(shù)字數(shù)量
    // 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)" ;
        }
    };
    /*
    * 旋轉(zhuǎn)指定“圓圈”指定度數(shù)
    * */
    let rotateTag = function(tag , deg){
        tag.style.transform = "rotate("+deg+"deg)";
    };

    let main = function(){
        initRili(); // 初始化日歷

        setInterval(function(){
            let mydate = new Date();
            showNow( mydate ); // 展示當(dāng)前時間
        },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>

以上就是JS+CSS3實現(xiàn)時鐘效果(抖音)的詳細內(nèi)容,更多請關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!

本文題目:javascript和CSS3實現(xiàn)時鐘效果
URL地址:http://aaarwkj.com/article14/gjdgge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、App設(shè)計微信小程序、品牌網(wǎng)站制作標簽優(yōu)化、網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)
精品一区精品二区国产日韩| 亚洲综合激情另类专区| 少妇高潮叫床免费网站在线观看| 欧美一区二区三区午夜| 精品国产美女诱惑久久久| 亚洲精品熟女国产中文| 国产乡下三级_三级全黄| 亚洲,日韩,欧美久久综合| 国产传媒在线视频观看| 日本免费一区二区三区手机在线 | 香蕉网性欧美在线视频| 成人精品午夜福利视频| 日本成人午夜电影网站| 国产在线麻豆在拍91精品| 乱码人妻精品一区二区三区| 成人在线免费观看视频国产| 日韩精品在线观看一| 日韩欧美精品在线观看免费| 欧美福利免费在线视频| 国内熟妇人妻色在线三级| 97福利影院在线观看| 亚洲欧美一区二区三区日本| 日本少妇三级网站大全| 九九热精品视频美谷朱里| 四虎国产精品久久久久久网址 | 成人看片亚欧大片在线观看| 性感美女国产av一区二区三区| 五月婷婷六月丁香俺来也| 亚洲欧美日韩国产一区| 国产精品传媒在线视频| 日本乱一区二区三区在线| 亚洲午夜精品理论在线不卡| 国产高清视频在线观看流白浆| 中出亚洲精品日韩在线视频| 无套内射精品一区二区| 国产乱子一区二区三区| 亚洲中国av一区二区| 亚洲中文字幕激情中午字幕| 中文字幕在线日韩精品| 亚洲av日韩高清在线观看| 高清亚洲一区二区三区|