0

0

动态显示“Last Refreshed X ago”倒计时的前端实现方案

花韻仙語

花韻仙語

发布时间:2026-03-11 14:33:13

|

806人浏览过

|

来源于php中文网

原创

本文详解如何在网页中稳定、连续地显示“last refreshed x ago”动态时间戳,支持页面刷新不重置、5分钟周期自动归零,并兼容秒/分单位智能切换。

本文详解如何在网页中稳定、连续地显示“last refreshed x ago”动态时间戳,支持页面刷新不重置、5分钟周期自动归零,并兼容秒/分单位智能切换。

在构建实时数据看板(如 Twitter 热搜趋势)时,一个关键的用户体验细节是准确、可信地展示数据新鲜度——例如 “Last Refreshed 2 min ago”。但若仅依赖 Date.now() 在页面加载时初始化计时器,将导致两个典型问题:(1)浏览器刷新后倒计时重置为 0;(2)API 实际已更新,但前端计时器仍持续累加,超出 5 分钟后失去业务意义

根本解法在于:将“最后一次成功刷新数据的时间点”持久化存储于客户端,并以此为基准实时计算相对时长。localStorage 是最轻量、可靠且无需服务端改造的选择——它跨会话保留数据,且读写性能优异。

✅ 核心实现逻辑

  1. 初始化时间戳:首次加载时,若 localStorage 中无 startTime,则写入当前 Unix 时间(秒级);否则直接读取。
  2. 实时更新显示:每秒执行一次 updateTimer(),用当前时间减去 startTime 得到 elapsedSeconds。
  3. 智能格式化与自动归零:在 formatTime() 中判断 elapsedSeconds >= 300(即 ≥5 分钟),一旦触发,立即更新 startTime 并同步写入 localStorage,使下一次计算从 0 开始——这确保了时间显示永远反映「距上一次真实 API 成功调用」的真实间隔。
  4. 解耦数据获取与计时:fetchAndUpdateHashtags() 每 5 分钟调用一次 API;计时器独立运行,二者通过 localStorage 协同,无强依赖。

以下是精简、健壮的前端实现代码(已移除冗余服务端逻辑,聚焦核心时序控制):

纳米漫剧流水线
纳米漫剧流水线

360推出的国内首个工业级AI漫剧生产平台

下载
<!DOCTYPE html>
<html>
<head>
  <title>Trending Hashtags</title>
  <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
</head>
<body>
  <h1>Trending Hashtags</h1>
  <div id="hashtags-container"></div>
  <div id="timestamp-container">
    <span class="timestamp">Last Refreshed: -</span>
  </div>

  <script>
    // 从 localStorage 初始化 startTime,保证刷新不丢失
    let startTime = parseInt(localStorage.getItem('lastRefreshTime')) || Math.floor(Date.now() / 1000);

    function updateTimer() {
      const now = Math.floor(Date.now() / 1000);
      const elapsed = now - startTime;
      updateTimestamp(elapsed);
    }

    function updateTimestamp(seconds) {
      const el = document.querySelector('#timestamp-container .timestamp');
      if (el) {
        el.textContent = `Last Refreshed: ${formatTime(seconds)} ago`;
      }
    }

    function formatTime(seconds) {
      // ⚠️ 关键:达到 5 分钟即重置计时器,模拟“刚完成刷新”
      if (seconds >= 300) {
        startTime = Math.floor(Date.now() / 1000);
        localStorage.setItem('lastRefreshTime', startTime.toString());
        return '0 sec';
      }

      const mins = Math.floor(seconds / 60);
      const secs = seconds % 60;
      return mins > 0 ? `${mins} min` : `${secs} sec`;
    }

    // 每秒更新时间显示
    setInterval(updateTimer, 1000);

    // 每 5 分钟拉取新数据(触发重置逻辑)
    function fetchAndUpdateHashtags() {
      fetch('/trends')
        .then(res => res.json())
        .then(data => {
          const container = document.getElementById('hashtags-container');
          container.innerHTML = data.data.map((item, i) => 
            `<div class="trend-item">
              <span>${i + 1}.</span>
              <span>${item.hashtag}</span>
              <span class="text-secondary">${formatTweetVolume(item.tweetCount)}</span>
            </div>`
          ).join('');
        })
        .catch(err => console.error('Fetch failed:', err));
    }

    function formatTweetVolume(vol) {
      return vol >= 1000 ? (vol / 1000).toFixed(1) + 'k' : vol;
    }

    // 启动轮询(注意:初始加载也应触发一次)
    fetchAndUpdateHashtags();
    setInterval(fetchAndUpdateHashtags, 300 * 1000); // 5 minutes
  </script>

  <style>
    .trend-item { margin: 8px 0; font-family: -apple-system, sans-serif; }
    .text-secondary { color: #666; font-size: 0.9em; }
  </style>
</body>
</html>

⚠️ 注意事项与最佳实践

  • 服务端无需提供 /start-time 接口:原方案中该接口易引发时钟漂移(客户端和服务端时间不同步)。本方案完全由客户端维护 startTime,更精准、更简单。
  • localStorage 安全性:仅存储时间戳(纯数字),无敏感信息,符合安全规范。
  • 错误容错:若某次 fetch 失败,计时器不会重置,用户仍能感知“数据已过期”,符合真实场景预期。
  • 可扩展性:如需支持小时、天级显示(如 2 hours ago),只需扩展 formatTime() 的判断分支,逻辑清晰易维护。
  • SEO 与首屏体验:时间戳初始值 - 可替换为服务端渲染的静态时间(如 SSR 注入 lastRefreshTime),兼顾首屏速度与准确性。

通过这一设计,你获得的不仅是一个动态时间标签,更是一个具备状态一致性、用户信任感和工程鲁棒性的数据时效指示系统——它默默工作,却让每一次刷新都值得信赖。

立即学习前端免费学习笔记(深入)”;

相关标签:

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1902

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

656

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2387

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

unix和linux的区别
unix和linux的区别

unix和linux的区别包括发展历史、开源性、发行版本、内核、文件系统、应用程序兼容性和用户界面等。本专题为大家提供unix和linux相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.09.22

seo页面描述
seo页面描述

一个好的SEO页面描述应该包含关键词、简明扼要地概括网页的主题和内容、具有吸引力、与网页内容相符,并且是独特的。它不仅可以帮助搜索引擎了解网页的内容,还可以吸引用户点击进入网页。因此,编写一个优秀的SEO页面描述对于网页的排名和点击率都非常重要。

218

2023.08.31

wordpress seo
wordpress seo

WordPress网站SEO优化方法有:1、选择一个SEO友好的主题,具有清晰的代码结构,快速的加载速度和响应式设计;2、使用SEO插件,优化你的标题标签,元描述,关键字,XML站点地图等;3、优化你的内容,内容是SEO优化的核心;4、优化你的网站速度;5、创建友好的URL;6、使用内部链接;7、优化图像;8、使用社交媒体;9、定期更新你的网站;10、监控和分析你的网站等等。

435

2023.09.18

SEO诊断方法有哪些
SEO诊断方法有哪些

SEO诊断是一个综合性的工作,需要从网站结构、关键词优化、内容质量、外部链接、网站速度、移动友好性等多个方面进行评估和优化。通过进行SEO诊断,可以帮助网站提高在搜索引擎中的排名,从而增加流量和曝光度 。

298

2023.10.09

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

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