0

0

PHP 与 Moment.js 实现精准倒计时(5分钟示例)

心靈之曲

心靈之曲

发布时间:2026-02-14 19:43:07

|

858人浏览过

|

来源于php中文网

原创

PHP 与 Moment.js 实现精准倒计时(5分钟示例)

本文详解如何结合 php 动态生成目标时间戳、moment.js 进行客户端倒计时渲染,并纠正常见误区(如误将 unix 时间戳当持续时间),提供可直接运行的完整代码与健壮格式化方案。

本文详解如何结合 php 动态生成目标时间戳、moment.js 进行客户端倒计时渲染,并纠正常见误区(如误将 unix 时间戳当持续时间),提供可直接运行的完整代码与健壮格式化方案。

在 Web 开发中,实现“从当前时刻开始倒计时 5 分钟”看似简单,但极易因混淆 时间点(timestamp)时间间隔(duration) 而出错。原代码中 moment.duration(1646486515 * 1000, 'milliseconds') 实际是将一个 Unix 时间戳(代表 2022 年某刻)当作毫秒数传入,导致创建了一个长达 52 年的无效“持续时间”,而非期望的 300 秒倒计时。

正确思路应分三步:

  1. PHP 端计算目标截止时间点(如 time() + 300),并将其安全传递给 JS;
  2. JS 端基于当前时间动态计算剩余时长(避免依赖服务端静态值,防止时钟不同步);
  3. 用 Moment.js 的 duration 对象规范提取并格式化 hours()/minutes()/seconds(),而非错误地调用 moment(...).format()。

以下是优化后的完整实现:

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css" rel="stylesheet">
    <title>5-Minute Countdown</title>
    <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.29.1/moment.min.js"></script>
</head>
<body>
    <div class="container mt-4">
        <h1 class="text-center mb-4">倒计时演示:5 分钟</h1>
        <div class="p-4 bg-light rounded shadow-sm">
            <p><strong>当前服务器时间:</strong><?php echo date('Y-m-d H:i:s'); ?></p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/7fc7563c4182" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">PHP免费学习笔记(深入)</a>”;</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/1221" title="LogoMaker"><img
                                                                                src="https://img.php.cn/upload/ai_manual/001/431/639/68b7a0863fbc1815.png" alt="LogoMaker"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/1221" title="LogoMaker">LogoMaker</a>
                                                                        <p>免费在线制作Logo,在几分钟内完成标志设计</p>
                                                                </div>
                                                                <a href="/ai/1221" title="LogoMaker" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div>
            <p><strong>倒计时目标时间:</strong><?php echo date('Y-m-d H:i:s', time() + 300); ?></p>
            <p><strong>剩余时间:</strong><span id="countdown" class="fw-bold fs-4 text-primary">00:05:00</span></p>
        </div>
    </div>

    <script>
        // ✅ 正确方式:PHP 提供倒计时总秒数(非时间戳!)
        const TOTAL_SECONDS = <?php echo 300; ?>;

        // 初始化倒计时 duration 对象
        let duration = moment.duration(TOTAL_SECONDS, 'seconds');

        // 每秒更新
        const timer = setInterval(() => {
            // 减少 1 秒
            duration = moment.duration(duration.asSeconds() - 1, 'seconds');

            // ✅ 安全格式化:使用 duration 方法 + 零填充
            const h = Math.floor(duration.asHours()) % 24;
            const m = String(duration.minutes()).padStart(2, '0');
            const s = String(duration.seconds()).padStart(2, '0');
            $('#countdown').text(`${h}:${m}:${s}`);

            // ⚠️ 注意:此处判断需考虑负数边界,建议用 asSeconds() >= 0
            if (duration.asSeconds() <= 0) {
                clearInterval(timer);
                $('#countdown').text('00:00:00');
                alert('倒计时结束!');
                // window.location.replace(window.location.href); // 如需刷新可启用
            }
        }, 1000);
    </script>
</body>
</html>

关键改进说明:

  • 语义清晰:moment.duration(300, 'seconds') 明确表示“300 秒的持续时间”,杜绝时间戳误用;
  • 格式可靠:不再调用 moment(duration.ms).format()(该写法会将毫秒数解释为 Unix 时间戳,导致显示 1970 年时间),而是通过 duration.hours()、duration.minutes() 等方法获取各字段,并用 padStart(2, '0') 保证两位数显示;
  • 逻辑健壮:使用 duration.asSeconds()
  • 可扩展性强:若需动态设定倒计时(如用户选择 3/5/10 分钟),只需修改 PHP 中 即可,前端逻辑完全复用。

注意事项:

  • 客户端倒计时受用户系统时间影响,对高精度场景(如支付超时),必须配合服务端校验或使用 WebSocket 同步时间;
  • moment.js 已进入维护模式,新项目推荐迁移到 Luxon 或原生 Intl.DateTimeFormat + Date API;
  • 生产环境请移除 alert(),改用 Toast 提示或状态回调。

掌握时间点与持续时间的本质区别,是构建稳定倒计时功能的第一步——代码简洁,逻辑清晰,方能万无一失。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

865

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

445

2024.06.27

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

521

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

371

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5600

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

488

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

214

2023.09.04

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 11.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号