Heim >Web-Frontend >js-Tutorial >JavaScript implementiert das Projekt „Creative Clock'.

JavaScript implementiert das Projekt „Creative Clock'.

一个新手
一个新手Original
2018-05-30 14:36:522287Durchsuche

Beschreibungsdokument „Clock Display Project“ (Das Dokument hat den entsprechenden Code am Ende)

1 Anzeige:

2. Projekt-Highlights

1. Die Codestruktur ist klar und deutlich

2. Kann die aktuelle Uhrzeit und das aktuelle Datum dynamisch in Echtzeit anzeigen

3. Die Benutzeroberfläche ist einfach, schön und großzügig

4. Verbessert die Browserkompatibilität

3. Zusammenfassung der Wissenspunkte:

jQuery, natives Javascript, CSS3, h5

Erklärung wichtiger und schwieriger Punkte

1. Ermitteln des Drehwinkels jedes Zeigers

Zunächst müssen wir die folgenden Konzepte klären:

Der Uhrzeiger dreht sich um 360 Grad im Kreis

Stundenzeiger:

Das Zifferblatt dreht sich jede Stunde um 30 Grad Minutenzeiger:

Auf dem Zifferblatt sind insgesamt 60 Stunden angezeigt. Jede Minute bewegt sich der Minutenzeiger um 6 Grad >

Sekundenzeiger:

Auf dem Zifferblatt befinden sich insgesamt 60 kleine Gitter, jede Minute, in der sich der Sekundenzeiger bewegt, durchläuft er ein kleines Gitter und dreht sich um 6 Grad;

(1) Ermitteln der aktuellen Zeit

Zum Beispiel Beispiel (am Beispiel der Berechnung des Stundenzeigerdrehwinkels). ): Die aktuelle Zeit ist beispielsweise 9:28; , müssen Sie auch die aktuelle Minute ermitteln, um den Drehwinkel des Stundenzeigers besser bestimmen zu können, der wie folgt lautet:

(2) Drehung Ermitteln des Winkels

Da sich der Stundenzeiger nach jeder Stunde um 30 Grad dreht, ergibt sich der Drehwinkel des Stundenzeigers wie folgt:

Ebenso der Winkel der Minute Zeiger und Sekundenzeiger Der Drehwinkel ist wie folgt:

Minutenzeiger:

Sekundenzeiger:

Um die Uhr genauer zu machen, ist sie hier auf Millisekunden genau

(3) Ausführungsfrequenz, d. h. Steuerung der Rotationsfrequenz des Sekundenzeigers

Passen Sie das Ausführungszeitintervall der Funktion an, um die Rotationsfrequenz des Sekundenzeigers zu ändern.

5. Projektoptimierungsbereiche

1. Die Seite ist zu prägnant und muss weiter optimiert und verbessert werden

2. Beim Zeichnen bleibt keine Zeit, Minuten und Sekunden auf die Uhr zu zeichnen.

6. Codes für jeden Teil des Projekts

1 .css-Code

Code anzeigen

3.js-Code

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>jQuery指针时钟(附带日期)</title>
    <!--引入外部css样式-->
    <link rel="stylesheet" href="css/demo.css" type="text/css" media="screen" />
</head>
<body>
    <!--引入jQuery库文件-->
    <script src="js/jquery-1.6.2.min.js"></script>
    <!--引入外部js文件-->
    <script src="js/script.js"></script>
    <p style="text-align:center;clear:both">
    </p>
</body>
</html>
(1) Sie müssen ein js-Referenzpaket herunterladen (Baidu oder Google, du weißt es einfach)

(2) js-Code
*
{
    margin:0;
    padding:0;
}
body
{
    background:#f9f9f9;
    color:#000;
    font:15px Calibri, Arial, sans-serif;
    text-shadow:1px 2px 1px #FFFFFF;
}
a,
a:visited
{
    text-decoration:none;
    outline:none;
    color:#fff;
}
a:hover
{
    text-decoration:underline;
    color:#ddd;
}
     /*the footer  (尾部)*/
footer
{
    background:#444 url("../images/bg-footer.png") repeat;
    position:fixed;
    width:100%;
    height:70px;
    bottom:0;
    left:0;
    color:#fff;
    text-shadow:2px 2px #000;
    /*提高浏览器的兼容性*/
    -moz-box-shadow:5px 1px 10px #000;
    -webkit-box-shadow:5px 1px 10px #000;
    box-shadow:5px 1px 10px #000;
}
footer h1
{
    font:25px/26px Acens;
    font-weight:normal;
    left:50%;
    margin:0px 0 0 150px;
    padding:25px 0;
    position:relative;
    width:400px;
}
footer a.orig,
a.orig:visited
{
    background:url("../images/demo2.png") no-repeat right top;
    border:none;
    text-decoration:none;
    color:#FCFCFC;
    font-size:14px;
    height:70px;
    left:50%;
    line-height:50px;
    margin:12px 0 0 -400px;
    position:absolute;
    top:0;
    width:250px;
}
     /*styling for the clock(时钟样式)*/
#clock
{
    position: relative;
    width: 600px;
    height: 600px;
    list-style: none;
    margin: 20px auto;
    background: url(&#39;../images/clock.png&#39;) no-repeat center;
    
}
#seconds,
#minutes,
#hours
{
    position: absolute;
    width: 30px;
    height: 580px;
    left: 270px;
}
#date
{
    position: absolute;
    top: 365px;
    color: #666;
    right: 140px;
    font-weight: bold;
    letter-spacing: 3px;
    font-family: "微软雅黑";
    font-size: 30px;
    line-height: 36px;
}
#hours
{
    background: url(&#39;../images/hands.png&#39;) no-repeat left;
    z-index: 1000;
}
#minutes
{
    background: url(&#39;../images/hands.png&#39;) no-repeat center;
    width:25px;
    z-index: 2000;
}

#seconds
{
    background: url(&#39;../images/hands.png&#39;) no-repeat right;
    z-index: 3000;
}

4. Einige notwendige Bildmaterialien (c werden hier nicht einzeln aufgelistet oder angezeigt)

Hinweise:

1.Transform-Attribut

$(document).ready(function () {
    //动态插入HTML代码,标记时钟    
    var clock = [
        &#39;<ul id="clock">&#39;,
        &#39;<li id="date"></li>&#39;,
        &#39;<li id="seconds"></li>&#39;,
        &#39;<li id="hours"></li>&#39;,
        &#39;<li id="minutes"></li>&#39;,
        &#39;</ul>&#39;].join(&#39;&#39;);
    // 逐渐显示时钟,并把它附加到主页面中    
    $(clock).fadeIn().appendTo(&#39;body&#39;);
    //每一秒钟更新时钟视图的自动执行函数
    //也可以使用此方法: setInterval (function Clock (){})();
    (function Clock() {
        //得到日期和时间
        var date = new Date().getDate(),        //得到当前日期
           hours = new Date().getHours(),       //得到当前小时
         minutes = new Date().getMinutes();        //得到当前分钟
         seconds = new Date().getSeconds(),     //得到当前秒
              ms = new Date().getMilliseconds();//得到当前毫秒
        //将当前日期显示在时钟上
        $("#date").html(date);
        //获取当前秒数,确定秒针位置
        var srotate = seconds + ms / 1000;
        $("#seconds").css({
            //确定旋转角度
            &#39;transform&#39;: &#39;rotate(&#39; + srotate * 6 + &#39;deg)&#39;,       
        });
        //获取当前分钟数,得到分针位置
        var mrotate = minutes + srotate / 60; 
        $("#minutes").css({
            &#39;transform&#39;: &#39;rotate(&#39; + mrotate * 6 + &#39;deg)&#39;,
            //提高浏览器的兼容性
            &#39;-moz-transform&#39;: &#39;rotate(&#39; + mrotate * 6 + &#39;deg)&#39;,
            &#39;-webkit-transform&#39;: &#39;rotate(&#39; + mrotate * 6 + &#39;deg)&#39;
        });
        //获取当前小时,得到时针位置
        var hrotate = hours % 12 + (minutes / 60);
        $("#hours").css({
            &#39;transform&#39;: &#39;rotate(&#39; + hrotate * 30 + &#39;deg)&#39;,
            //提高浏览器的兼容性
            &#39;-moz-transform&#39;: &#39;rotate(&#39; + hrotate * 30 + &#39;deg)&#39;,
            &#39;-webkit-transform&#39;: &#39;rotate(&#39; + hrotate * 30 + &#39;deg)&#39;
        });
        //每一秒后执行一次时钟函数
        setTimeout(Clock, 1000);
    })();
});

2.rotate()-Methode

Das obige ist der detaillierte Inhalt vonJavaScript implementiert das Projekt „Creative Clock'.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn