时间滚动

现满足需求

  • 1.5(time1)分钟请求一次接口

    2.每次请求接口随机数脚本停止5(time2)秒钟

    3.没2(time3)秒执行一次随机数脚本

    在这里插入图片描述

    话不多说,直接上代码

html版块
<!DOCTYPE html>
<html lang="en">

<head>
    <title></title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<style>
    .list-content{
        text-align: center;
        margin-top: 300px;
    }
    .list {
        height: 84px;
        font-size: 0;
        letter-spacing: -5px;
        white-space: nowrap;
    }

    .list i {
        position: relative;
        display: inline-block;
        width: 64px;
        height: 84px;
        text-align: center;
        color: #e8cd92;
        font-size: 28px;
        letter-spacing: 0;
        overflow: hidden;
        margin-right: 3px;
    }

    .list span {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 840px;
        background: url() no-repeat;
        background-size: 100% 100%;
    }

    .list b {
        display: inline-block;
        font-size: 28px;
        margin-right: 3px;
    }
</style>

<body>
    <div class="list list-content"></div>

</body>
<script src="http://prewww.jtexpress.com.cn/js/common/jquery.min.js"></script>
<script src="./index.js"></script>

</html>


js版块

/*
现满足需求
5(time1)分钟请求一次接口
每次请求接口随机数脚本停止5(time2)秒钟
没2(time3)秒执行一次随机数脚本
**/

/*
取值规则[randomMinNum <= randomNum < randomMaxNum]
numberALL: 请求接口的具体数字
randomMinNum: 随机最小数
randomMaxNum: 随机最大数
randomNum: 某一次的随机数
randomstate:是否开启随机脚本
setTimeout1:  每5分钟执行一次ajax
setTimeout2 每n秒执行一次随机数脚本
setTimeout3 停止多少秒执行随机数脚本
time1:  执行接口时间
tiem2: 执行随机数脚本时间
time3: 执行停止随机数脚本时间
**/
var numberALL = "52568945465"
var randomMinNum = 2,
    randomMaxNum = 200,
    randomNum,
    randomstate = false,
    setTimeout1,
    setTimeout2,
    setTimeout3,
    time1 = 5 * 60,
    time2 = 5,
    time3 = 2;

ajaxFun();

//请求接口
function ajaxFun() {
    clearTimeout(setTimeout1)
    clearTimeout(setTimeout2)
    clearTimeout(setTimeout3)
    randomstate = false;
    numberALL = parseInt(numberALL) + 10000 //请求接口
    numberRoll('.list', numberALL, 1000, true);
    setTimeout1 = setTimeout(ajax, time1 * 1000);
    randomstate = true;
    if (randomstate) {
        setTimeout3 = setTimeout(random1Second, time2 * 1000)
    }
}

// 随机数脚本
function random1Second() {
    clearTimeout(setTimeout2)
    randomNum = parseInt(Math.random() * (randomMaxNum - randomMinNum) + randomMinNum, 10)
    numberALL = parseInt(numberALL + randomNum)
    // console.log(numberALL)
    numberRoll('.list', numberALL, 800, true);
    setTimeout2 = setTimeout(random1Second, time3 * 1000);
}

// 数字滚动
function numberRoll(obj, number, speed, hasComma) {
    var $obj = $(obj),
        numStr = String(number),
        len = numStr.length,
        h = $obj.height(),
        i;

    // 如果新的数字短于当前的,要移除多余的i
    if ($obj.find('i').length > len) {
        $obj.find('i:gt(' + (len - 1) + ')').remove();
    }

    // 移除千分位分隔符
    if (hasComma) {
        $obj.find('b').remove();
    }

    for (i = 0; i < len; i++) {
        // 位数不足要补
        if ($obj.find('i').length < len) {
            $obj.append('<i><span></span></i>');
        }

        // 加分隔符
        if (hasComma && i < len - 1 && (len - i - 1) % 3 === 0) {
            $('<b >,</b>').insertAfter($obj.find('i').eq(i));
        }
        // console.log($obj.height())
        $obj.find('i').eq(i).find("span").animate({
            "top": -(numStr.charAt(i) * h)
        }, speed || 1000);
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值