倒计时

Posted lightbc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了倒计时相关的知识,希望对你有一定的参考价值。

项目地址

html代码

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>倒计时</title>
        <link rel="stylesheet" type="text/css" href="layui/css/layui.css" />
        <script type="text/javascript" src="js/jquery-3.4.1.js"></script>
    </head>
    <body>
        <table border="0">
            <tr>
                <td>
                    选择时间:
                </td>
                <td>
                    <input type="text" id="date" class="layui-input date" />
                </td>
            </tr>
            <tr>
                <td>
                    倒计时:
                </td>
                <td>
                    <input type="text" id="countDownTime" class="layui-input date" readonly />
                </td>
            </tr>
            <tr>
                <td colspan="2">
                    <button type="text" id="startCountDown" class="layui-btn opt-btn" data-val="">开始</button>
                    <button type="text" id="stopCountDown" class="layui-btn opt-btn">暂停</button>
                </td>
            </tr>
        </table>
    </body>
</html>
<script type="text/javascript" src="layui/layui.js"></script>

CSS代码

<style type="text/css">
            table {
                text-align: center;
                margin: auto;
            }

            table tr td {
                padding: 10px 5px;
            }

            .date {
                width: 275px;
                height: 38px;
                text-align: center;
                display: inline-block;
            }

            .opt-btn {
                width: 100px;
            }
        </style>

JavaScript代码

<script type="text/javascript">
    // 组件
    layui.use(‘laydate‘, function() {
        var laydate = layui.laydate;
        laydate.render({
            elem: ‘#date‘,
            type: ‘datetime‘,
            value: new Date(),
            min: 0,
            done: function(value) {
                stat = 0;
                // 重新选择时间后清除interval
                if (timer != "") {
                    clearInterval(timer);
                    timer = "";
                    $("#countDownTime").val("");
                }
                $("#startCountDown").attr("data-val", value);
            }
        });
    });

    function countDown(id, value) {
        // 选择的时间
        var endTime = new Date(value);
        // 现在时间
        var nowTime = new Date();
        // 时间差(秒)
        var timeDiff = parseInt((endTime - nowTime) / 1000);
        var days = Math.floor(timeDiff / (24 * 60 * 60));
        var remTime = timeDiff % (24 * 60 * 60);
        var hours = Math.floor(remTime / (60 * 60));
        var remMinutes = remTime % (60 * 60);
        var minutes = Math.floor(remMinutes / 60);
        var seconds = remTime % 60;

        days = days > 9 ? days : "0" + days;
        hours = hours > 9 ? hours : "0" + hours;
        minutes = minutes > 9 ? minutes : "0" + minutes;
        seconds = seconds > 9 ? seconds : "0" + seconds;

        var ct = days + "天" + hours + "小时" + minutes + "分钟" + seconds + "秒";

        $("#" + id).val(ct);
    }

    // 开始倒计时
    // interval
    var timer = "";
    // 按钮状态
    var stat = 0;
    $("#startCountDown").click(function() {
        var value = $("#startCountDown").attr("data-val");
        // 选择的时间
        var endTime = new Date(value);
        // 现在时间
        var nowTime = new Date();
        if (value != "" && endTime>nowTime) {
            if(stat == 0){
                stat = 1;
                timer = setInterval(function() {
                    countDown("countDownTime", value);
                }, 1000);
            }
        } else {
            alert("请选择正确的时间(大于当前时间)!");
        }
    });

    // 暂停倒计时
    $("#stopCountDown").click(function() {
        if(stat == 1){
            stat = 0;
            if (timer != "") {
                clearInterval(timer);
                timer = "";
            }
        }
    });
</script>

效果展示:

技术图片

 

以上是关于倒计时的主要内容,如果未能解决你的问题,请参考以下文章

如何在使用片段和计时器的选项卡式活动上更新 UI

如何实现React原生倒计时圈

自动刷新android片段,直到满足条件

如果用户没有使用浏览器,则jQuery计时器停止

颤振计时器仅更新秒小部件

#yyds干货盘点#愚公系列2023年02月 .NET/C#知识点-程序运行计时的总结