js实现带翻转动画图片时钟

本文实例为大家分享了js实现带翻转动画图片时钟的具体代码,供大家参考,具体内容如下

首先上图,先看效果

1、需求

根据当前系统时间来更改这个时钟,更改时间时,数字向上翻动,转成下一个数字。

2、编程思路

如果只是根据系统时间来更改图片的话,其实很简单,就是获得每个数字图片的DOM,获得当前系统时间,然后更改其src为指定数字图片就可以了。但是这边想要加入这个反转动画,我们可以指定一个窗口,高度为一个数字图片的大小,再检测到时间变化时,我们在指定的数字图片后加入我们想要改变的数字图片结点,之后设置一个定时器用很小的时间不断向上移动,这样就能出这个上翻的动画效果,等上升了一个数字图片高度之后,删除上面的第一个结点。由此往复,即可实现。

3、代码实现

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<style>
    *{
        padding: 0;
        margin: 0;
    }
    .number{
        height: 70px;
        overflow: hidden;
        float: left;
    }
    .number img{
        display: block;
    }
</style>
<body>

<div>
    <div id="shi1" class="number">
        <img  src="img/0.jpg" />
    </div>
    <div id="shi2" class="number">
        <img  src="img/0.jpg" />
    </div>
    <div class="number">
        <img src="img/c.jpg" />
    </div>
    <div id="fen1" class="number">
        <img  src="img/0.jpg" />
    </div>
    <div id="fen2" class="number">
        <img  src="img/0.jpg" />
    </div>
    <div class="number">
        <img src="img/c.jpg" />
    </div>

    <div id="miao1" class="number">
        <img  src="img/0.jpg" />
    </div>
    <div id="miao2" class="number">
        <img  src="img/0.jpg" />
    </div>

</div>

<script>

    var shi1D = document.getElementById('shi1');
    var shi2D = document.getElementById('shi2');
    var fen1D = document.getElementById('fen1');
    var fen2D = document.getElementById('fen2');
    var miao1D = document.getElementById('miao1');
    var miao2D = document.getElementById('miao2');

    function getTime() {
        var myDate = new Date();
        var mytime=myDate.toLocaleString('chinese', { hour12: false });
        //获得时间格式为2020/12/30 18:54:39 第一个split(' ')[1]获得18:54:39这个字符串,在对其.split('')获得[1,8,:,5,4,:,3,9]这个数组
        //由此得到,time[0]time[1]为小时,time[3]time[4]为分钟,time[6]time[7]为秒
        time = mytime.split(' ')[1].split('');
        // console.log(time);
        return new Array(time[0],time[1],time[3],time[4],time[6],time[7]);
    }

    var h1=0,h2=0,f1=0,f2=0,m1=0,m2=0;

    //更新小时1
    var ht1=0;
    setInterval(function () {
        var a = getTime();
        if (a[0]!=h1){
            h1=a[0];
            //获得当前的子结点
            var childImg = shi1D.getElementsByTagName('img')[0];
            var imgM = document.createElement('img');
            imgM.src='img/'+h1+'.jpg';
            shi1D.appendChild(imgM);
            var s1 = setInterval(function () {
                ht1+=1;
                shi1D.scrollTop=ht1;
                if (ht1>=70){
                    clearInterval(s1);
                    setTimeout(function () {
                        childImg.remove();
                        ht1=0;
                    },100)
                }
            },1)
        }
    },1000);
    //更新小时2
    var ht2=0;
    setInterval(function () {
        var a = getTime();
        if(a[1]!=h2){
            h2=a[1];
            //获得当前的子结点
            var childImg = shi2D.getElementsByTagName('img')[0];
            var imgM = document.createElement('img');
            imgM.src='img/'+h2+'.jpg';
            shi2D.appendChild(imgM);
            var m2 = setInterval(function () {
                ht2+=1;
                shi2D.scrollTop=mt1;
                if (ht2>=70){
                    clearInterval(m2);
                    setTimeout(function () {
                        childImg.remove();
                        ht2=0;
                    },100)
                }
            },1)
        }
    },1000);
    //更新分钟1
    var ft1=0;
    setInterval(function () {
        var a = getTime();
        if (a[2]!=f1){
            f1=a[2];
            //获得当前的子结点
            var childImg = fen1D.getElementsByTagName('img')[0];
            var imgM = document.createElement('img');
            imgM.src='img/'+f1+'.jpg';
            fen1D.appendChild(imgM);
            var m2 = setInterval(function () {
                ft1+=1;
                miao1D.scrollTop=ft1;
                if (ft1>=70){
                    clearInterval(m2);
                    setTimeout(function () {
                        childImg.remove();
                        ft1=0;
                    },100)
                }
            },1)
        }

    },1000);
    //更新分钟2
    var ft2=0;
    setInterval(function () {
        var a = getTime();
        if (a[3]!=f2){
            f2=a[3];
            //获得当前的子结点
            var childImg = fen2D.getElementsByTagName('img')[0];
            var imgM = document.createElement('img');
            imgM.src='img/'+f2+'.jpg';
            fen2D.appendChild(imgM);
            var m2 = setInterval(function () {
                ft2+=1;
                fen2D.scrollTop=ft2;
                if (ft2>=70){
                    clearInterval(m2);
                    setTimeout(function () {
                        childImg.remove();
                        ft2=0;
                    },100)
                }
            },1)
        }

    },1000);
    //更新秒1
    var mt1=0;
    setInterval(function () {
        var a = getTime();
       if (a[4]!=m1){
           m1=a[4];
           //获得当前的子结点
           var childImg = miao1D.getElementsByTagName('img')[0];
           var imgM = document.createElement('img');
           imgM.src='img/'+m1+'.jpg';
           miao1D.appendChild(imgM);
           var m2 = setInterval(function () {
               mt1+=1;
               miao1D.scrollTop=mt1;
               if (mt1>=70){
                   clearInterval(m2);
                   setTimeout(function () {
                       childImg.remove();
                       mt1=0;
                   },100)
               }
           },1)
       }
    },1000);
    //更新秒2
    var mt2=0;
    setInterval(function () {
        var a = getTime();
        //获得当前的子结点
        var childImg = miao2D.getElementsByTagName('img')[0];
        // miao2D.src='img/'+a[5]+'.jpg'
        var imgM = document.createElement('img');
        imgM.src='img/'+a[5]+'.jpg';
        miao2D.appendChild(imgM);
        var m2 = setInterval(function () {
            mt2+=1;
            // console.log(mt2);
            miao2D.scrollTop=mt2;
            if (mt2>=70){
                clearInterval(m2);
                setTimeout(function () {
                    childImg.remove();
                    mt2=0;
                },100)
            }
        },1)

    },1000);
</script>

</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • JavaScript实现简单的时钟实例代码

    复制代码 代码如下: <html> <head> <title>JS实现简单的时钟</title><script> function displayTime() {        document.getElementById("time").innerHTML = new Date().toTimeString();    } setInterval(displayTime,1000);      // 每隔1秒钟调用dis

  • js实现一个简单的数字时钟效果

    效果图: 代码如下: <!DOCTYPE HTML> <html> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>一个简单的数字时钟</title> <script type="text/javascript" charset="utf-8

  • js实现图片实时时钟

    本文实例为大家分享了js实现图片实时时钟的具体代码,供大家参考,具体内容如下 描述: 将下图作为时间的背景,实现随时时钟的效果. 效果: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> div div { float: left; width

  • JS实现图片数字时钟

    本文实例为大家分享了JS实现图片数字时钟的具体代码,供大家参考,具体内容如下 首先这是我们准备的图片 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> </style> </head> <body> <d

  • 五步轻松实现JavaScript HTML时钟效果

    学了一段时间的HTML.CSS和JS后,给大家做一款漂亮的不像实力派的HTML时钟,先看图: 涉及到的知识点有: CSS3动画.DOM操作.定时器.圆点坐标的计算(好多人是不是已经还给自己的老师了~)  接下来,我们用5步来制作它 step1.准备HTML 首先,我们需要准备HTML结构,背景.表盘.指针(时针.分针.秒针).数字. <div id="clock"> <div class="bg"> <div class="p

  • 基于javascript实现动态时钟效果

    本文实例讲解了javascript动态时钟效果的实现方法,分享给大家供大家参考,具体内容如下 实现代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <

  • html5 canvas js(数字时钟)实例代码

    复制代码 代码如下: <!doctype html><html>    <head>        <title>canvas dClock</title>    </head>    <body>        <canvas id = "clock" width = "500px" height = "200px">            您的浏览

  • JavaScript实现抖音罗盘时钟

    本文实例为大家分享了JavaScript实现抖音罗盘时钟的具体代码,供大家参考,具体内容如下 其实很早以前就想发了,很多东西其实并不难,只要多动手动脑就行了,下面直接上代码,其他的自己下去慢慢研究吧! HTML部分代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" co

  • js时钟翻牌效果实现代码分享

    先给大家上运行效果图,看看是不是特别棒! 这一张是小编抓拍时钟翻牌时的效果图: 为大家分享的JavaScript时钟翻牌效果代码如下 <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Create an Animated Flip Down Clock</title> <link rel=&quo

  • 一个简易时钟效果js实现代码

    本文实例为大家分享了js时钟特效 的具体代码,供大家参考,具体内容如下 js代码 var canvas = document.getElementById("clock"); var clock = canvas.getContext("2d"); function zhong() { clock.save(); //开始画外层圆 clock.translate(200, 200); clock.strokeStyle = 'black'; clock.lineWi

随机推荐