Maison  >  Article  >  interface Web  >  Utilisez H5 et C3 pour obtenir des effets d'horloge simples

Utilisez H5 et C3 pour obtenir des effets d'horloge simples

php中世界最好的语言
php中世界最好的语言original
2018-01-19 09:39:042162parcourir

Cette fois, je vais vous montrer comment utiliser H5 et C3 pour obtenir un effet d'horloge simple. Quelles sont les précautions concernant l'utilisation de H5 et C3 pour obtenir un effet d'horloge simple. , jetons un coup d'oeil.

Objectif :

Utiliser html5 et css pour obtenir l'effet pendule

Points de connaissance :

1) Utiliser position/gauche /top et calc() pour réaliser le centrage horizontal et vertical des éléments ;

2) Utilisez les attributs CSS3 animation/transform/transform-origin pour définir les animations

3) Utilisez transform-origin pour réaliser l'ajustement du centre du cercle d'origine de rotation

Plus de bêtises, regardons directement le code. Le code spécifique est le suivant :

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <style>
        li{
            list-style:none;
        }
        #box{
            width: 400px;
            height: 400px;
            position: absolute;
            top:calc(50% - 200px);
            left:calc(50% - 200px);
            border: 2px solid palegoldenrod;
        }
        #dial{
            width: 200px;
            height: 200px;
            position: absolute;
            top:calc(50% - 100px);
            left:calc(50% - 100px);
            border: 2px solid cyan;
            border-radius: 50%;
        }  
        .scaleIndex{
            width: 4px;
            height: 12px;
            position: absolute;
            top: 0;
            left: calc(50% - 2px);
            background-color: gray;
            transform-origin: 2px 100px;
        }
        .angle30{transform : rotate(30deg);}
        .angle60{transform : rotate(60deg);}
        .angle90{transform : rotate(90deg);}
        .angle120{transform : rotate(120deg);}
        .angle150{transform : rotate(150deg);}
        .angle180{transform : rotate(180deg);}
        .angle210{transform : rotate(210deg);}
        .angle240{transform : rotate(240deg);}
        .angle270{transform : rotate(270deg);}
        .angle300{transform : rotate(300deg);}
        .angle330{transform : rotate(330deg);}
        #fixPoint{
            width: 10px;
            height: 10px;
            position: absolute;
            top:calc(50% - 5px);
            left:calc(50% - 5px);
            background-color: cadetblue;
            border-radius: 50%;
        }
        #hourHand{
            width: 6px;
            height: 70px;
            position:absolute;
            top: 40px;
            left: calc(50% - 3px);
            background-color: darkblue;
            transform-origin: 50% 60px;
        }
        #minuteHand{
            width: 4px;
            height: 75px;
            position:absolute;
            top: 35px;
            left: calc(50% - 2px);
            background-color: yellow;
            transform-origin: 50% 65px;
        }
        #secondHand{
            width: 2px;
            height: 90px;
            position:absolute;
            top: 20px;
            left: calc(50% - 1px);
            background-color: red;
            transform-origin: 50% 80px;
        }
    </style>
</head>
<body>
    <div id = "box">
            <div id = &#39;dial&#39;>
                <ul id = "scale">
                    <li class = "scaleIndex"></li>
                    <li class = "scaleIndex angle30"></li>
                    <li class = "scaleIndex angle60"></li>
                    <li class = "scaleIndex angle90"></li>
                    <li class = "scaleIndex angle120"></li>
                    <li class = "scaleIndex angle150"></li>
                    <li class = "scaleIndex angle180"></li>
                    <li class = "scaleIndex angle210"></li>
                    <li class = "scaleIndex angle240"></li>
                    <li class = "scaleIndex angle270"></li>
                    <li class = "scaleIndex angle300"></li>
                    <li class = "scaleIndex angle330"></li>
                </ul>
                <div id = "fixPoint"></div>
                <div id = "hourHand"></div>
                <div id = "minuteHand"></div>
                <div id = "secondHand"></div>
            </div>
        </div>
<script type = &#39;text/javascript&#39; src = &#39;js/jquery-3.2.1.js&#39;></script>
<script type = "text/javascript">
window.onload = function(){
            var hourHand = document.getElementById(&#39;hourHand&#39;);
            var minuteHand = document.getElementById(&#39;minuteHand&#39;);
            var secondHand = document.getElementById(&#39;secondHand&#39;);
setInterval(function(){
                    var currentTime = new Date();
                    var hourValue = currentTime.getHours();
                    var hourAngle = hourValue / 24 * 360 + &#39;deg&#39;;
                    var minuteValue = currentTime.getMinutes();
                    var minuteAngle = minuteValue / 60 * 360 + &#39;deg&#39;;
                    var secondValue = currentTime.getSeconds();
                    var secondAngle = secondValue / 60 * 360 + &#39;deg&#39;;
                    console.log(hourAngle);
// 方法一:利用jquery的css()增加属性
var cmdHour = &#39;rotate(&#39;+ hourAngle +&#39;)&#39;;
$(&#39;#hourHand&#39;).css({transform:&#39;rotate(&#39;+ hourAngle +&#39;)&#39;});
var cmdMinute = &#39;rotate(&#39;+ minuteAngle +&#39;)&#39;;
$(&#39;#minuteHand&#39;).css({transform:cmdMinute});
var cmdSecond = &#39;rotate(&#39;+ secondAngle +&#39;)&#39;;
$(&#39;#secondHand&#39;).css({transform:cmdSecond});
 
// 方法二:利用DOM元素的style属性设置
//      hourHand.style.transform = &#39;rotate(&#39;+ hourAngle + &#39;)&#39;;
//      minuteHand.style.transform = &#39;rotate(&#39;+ minuteAngle + &#39;)&#39;;
//      secondHand.style.transform = &#39;rotate(&#39;+ secondAngle + &#39;)&#39;; 
 
},1000);
}
    </script>
</body>
</html>

Je pense que vous maîtrisez la méthode après avoir lu ceux-ci. cas. Veuillez prêter attention aux choses plus intéressantes. Autres articles connexes sur le site Web chinois de php !

Lecture connexe :

Comment implémenter le tri par glisser-déplacer de la souris dans un tableau HTML

À quel fichier appartient le HTML ? ouvrir

Html Comment obtenir l'effet de rapport d'affichage dynamique des blocs de couleur

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn