js数字滑动时钟

js数字滑动时钟:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style type="text/css">
        body,ul{margin:0;padding: 0;}
        .content{margin:100px auto;width: 1000px;}
        .box{position: relative;float: left;width: 50px;height: 120px;overflow: hidden;}
        .box li{position: absolute;left: 0;width:100%;height: 120px;list-style:none;font-size:80px;font-weight: bold;background-color: #fff; line-height: 120px; text-align: center;}
        .colon{float: left;height: 120px;font-size: 80px;color: #e91e63;font-weight: bold;line-height: 100px;}
    </style>
</head>
<body>
    <div class="content">
    </div>
    <script type="text/javascript">
    (function(){
        var colors = ["#69D2E7", "#E20049", "#19215E", "#F38630", "#FA6900", "#FF4E50", "#F9D423", "#FFB6FF", "#474168", "#6ACAFC"];
        var content = document.querySelector(‘.content‘);
        var num = 0;
        var height = 120;
        var maxheight = (2-num)*height;
        var timeNum = [3,10,6,10,6,10];
        var position = [];
        var NumberBoxs = [];
        for(var i =0;i<10;i++){
            position.push((1-i)*height);
        };
        function NumberBox() {}
        NumberBox.prototype = {
            init : function () {
                var innerHTML = "<div class=‘box‘ id=‘box"+num+"‘><ul>"
                this.num = num;
                num++;
                for(var i =0,l=timeNum[this.num];i<l;i++){
                    innerHTML += "<li style=‘color:"+colors[i]+"‘>"+i+"</li>";
                }
                innerHTML += "</ul><div>"
                content.innerHTML += innerHTML;
                if(num==2||num==4){content.innerHTML += "<div class=‘colon‘>:</div>"}
            },
            dominit : function(){
                this.Ali = [].slice.call(document.getElementById(‘box‘+this.num).getElementsByTagName(‘li‘),0);
                this.Ali.forEach(function(dom,i){
                    dom.style.top = position[i] + "px";
                    dom.style.transition = "top .8s";
                })
                this.hasdom = true;
            },
            toNum : function (n) {
                if(!this.hasdom){this.dominit();}
                n = ""+n;
                var p = this;
                var l = p.Ali.length-1;
                while(p.Ali[1].innerHTML!=n){
                p.Ali.unshift(p.Ali.pop());
                }
                p.Ali.forEach(function (dom,i) {
                dom.style.zIndex = (i==l)?"-1":"1";
                dom.style.top = position[i] + "px";
                })
            }
        }
        for(var i=0;i<6;i++){
            var o = new NumberBox();
            o.init();
            NumberBoxs.push(o);
        }
        function getTime() {
            var time = new Date();
            return (""+Fixed2(time.getHours())+Fixed2(time.getMinutes())+Fixed2(time.getSeconds())).split("");
        }
        function Fixed2(n){
            return Number(n)<10?"0"+n:n;
        }
        (function () {
            var time = getTime();
            NumberBoxs.forEach(function(obj,i){
                obj.toNum(time[i]);
            });
            setTimeout(arguments.callee,1000);
        })()
    })();
    </script>
</body>
</html>
时间: 2024-12-28 17:15:59

js数字滑动时钟的相关文章

【分享】JS图片滑动渐显渐隐插件-附使用方法。

前阵子总监要说做一个邀请函 效果 点击这里 鼠标拖拽进行浏览 它用的是Adobe edge软件生成的,代码量过大,冗余太多. 再加上我也没学过这个软件怎么使用,增加学习成本影响项目进度. 于是就自己写了个简单的.鼠标移动到右下角窗口滚动看效果→DEMO 不过是单体的 没有使用多个图片分频运动 ,当然如果项目需要的话,改起来也不费劲,比上面的要简单许多. 使用方法在下方: #bg{ position:fixed; width: 100%; height: 200%; background: url

一款常用的漂亮的JS图片滑动切换效果

<HTML> <HEAD> <TITLE>一款常用的漂亮的JS图片滑动切换效果丨石家庄展柜制作|</TITLE> <style> BODY { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; PADDING-TOP: 0px } UL { PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PAD

再议 js 数字格式之正则表达式

原文:再议 js 数字格式之正则表达式 前面我们提到到了js的数字格式<浅谈 js 数字格式类型>,之前的<js 正则练习之语法高亮>里也提到了优化数字匹配的正则.不过最近落叶给了我一个正则,让我豁然开朗,比我写的犀利多了,所以今天拿出来简单说一下(只说十进制部分的匹配). 先看下我之前写的正则:/\d+(?:\.\d+)?(?:[eE][+-]?\d+)?|\.\d+(?:[eE][+-]?\d+)?/落叶在 jQuery 中发现的正则: /(?:\d*\.|)\d+(?:[eE

js数字、字符串、数组之间的转化

1.数组转字符串 var a, b; a = new Array(0,1,2,3,4); b = a.join("-"); 2.字符串转数组 var s = "abc,abcd,aaa"; ss = s.split(","); 3.数字转字符串toString var i = 10; var s = i.toString(); 4.字符串转数字 parseInt(字符串) parseInt("ssss999"); //错误 输

浅谈 js 数字格式类型

原文:浅谈 js 数字格式类型 很多人也许只知道 123,123.456,0xff 之类的数字格式.其实 js 格式还有很多数字格式类型,比如 1., .1 这样的,也有 .1e2 这样的. 可能有人说这是什么个格式?其实还不止呢.1          //11.2       //1.21.2e3    //12001.2e+3  //12001.2e-3  //0.0012.12e+2 //12-.12e-2 //-0.0012 当然这些只是十进制.我们来说说 八进制 和 十六进制.0x00

js数字位数太大导致参数精度丢失问题

最近遇到个比较奇怪的问题,js函数里传参,传一个位数比较大,打印arguments可以看到传过来的参数已经改变. 然后查了一下,发现确实是js精度丢失造成的.我的解决方法是将数字型改成字符型传输,这样就不会造成精度丢失了.如下图: JS 数字丢失精度的原因 计算机的二进制实现和位数限制有些数无法有限表示.就像一些无理数不能有限表示,如 圆周率 3.1415926...,1.3333... 等.JS 遵循 IEEE 754 规范,采用双精度存储(double precision),占用 64 bi

JS数字键盘

JS数字键盘,JS小键盘 CSS代码: #numberkeyboard { border: 1px solid #b3b3b3; background: #f2f3f7; height: 285px; margin: 0; padding: 2px; position: relative; visibility: visible !important; width: 285px; } #numberkeyboard .numbtn { -moz-border-radius: 4px; /* Ge

分享一个很有意思的js,动态时钟显示,能跟随鼠标移动

原文:分享一个很有意思的js,动态时钟显示,能跟随鼠标移动 源代码下载地址:http://www.zuidaima.com/share/1550463688182784.htm

js绘制圆形时钟

纯js制作圆形时钟 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> *{ margin:0; padding:0; } body{ background: grey; } .box{ width:320px; height: 320px; borde