0

0

JavaScript倒计时持久化:避免页面刷新重置

碧海醫心

碧海醫心

发布时间:2025-10-02 11:13:36

|

376人浏览过

|

来源于php中文网

原创

JavaScript倒计时持久化:避免页面刷新重置

本文详细介绍了如何利用浏览器localStorage机制,实现一个在页面刷新后仍能保持其状态的JavaScript倒计时功能。通过在每次倒计时数值更新时将当前值存储到localStorage中,并在页面加载时从localStorage恢复,确保倒计时进程不被中断。文章还提供了完整的代码示例,并包含了一个重置倒计时的功能,以提升用户体验和功能完整性。

客户端状态持久化的挑战

在web开发中,许多交互式组件,如倒计时、购物车数量等,其状态通常存储在javascript变量中。然而,当用户刷新页面时,这些javascript变量会被重新初始化,导致组件状态丢失。对于一个正在进行的倒计时而言,这意味着每次页面刷新都会从头开始,这显然不是我们期望的行为。为了解决这个问题,我们需要一种机制来在客户端存储和检索数据,即使页面被刷新也能保持数据不变。

利用 localStorage 实现倒计时持久化

浏览器提供了多种客户端存储方案,其中 localStorage 是一个非常适合此场景的选择。localStorage 允许Web应用程序在用户的浏览器中存储键值对数据,这些数据在浏览器会话结束后仍然存在,直到被显式清除。

实现页面刷新不重置倒计时的核心思想是:

  1. 初始化时读取: 页面加载时,首先检查 localStorage 中是否存在之前保存的倒计时值。如果存在,则使用该值作为倒计时的起始值;如果不存在,则使用默认的初始值。
  2. 更新时存储: 在倒计时过程中,每当倒计时的数值发生变化时,都将最新的数值保存到 localStorage 中。
  3. 重置功能: 提供一个机制,允许用户手动重置倒计时,这通常意味着从 localStorage 中移除保存的值并刷新页面。

代码实现

下面是一个完整的示例代码,展示了如何结合 HTML 和 JavaScript 来实现一个持久化的随机减量倒计时。

HTML 结构

我们只需要一个 元素来显示倒计时数量,以及一个 button 元素来提供重置功能。

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


JavaScript 逻辑

JavaScript 部分是实现持久化倒计时的关键。我们将定义一个 setQty 函数来处理倒计时的更新和存储,并在页面加载时初始化倒计时。

代码解析与注意事项

  1. localStorage.getItem('saved_countdown') ?? 57;:

    通义万相
    通义万相

    通义万相,一个不断进化的AI艺术创作大模型

    下载
    • localStorage.getItem('saved_countdown') 用于从 localStorage 中检索名为 'saved_countdown' 的值。如果该键不存在,它将返回 null。
    • ?? (空值合并运算符) 是一个ES2020特性,它会在左侧操作数为 null 或 undefined 时返回右侧操作数。这意味着如果 localStorage 中没有保存的值,defaultQty 将被赋值为 57。
    • 重要提示: localStorage 存储的所有值都是字符串。虽然在 innerHTML 中直接使用字符串通常没有问题,但在进行数值计算前,最好使用 parseInt() 或 Number() 将其转换为数字类型,例如 setQty(parseInt(defaultQty, 10));。
  2. localStorage.setItem('saved_countdown', qty);:

    • 这是实现持久化的核心。在 setQty 函数内部,每次 qty 值更新后,我们都会立即将其保存到 localStorage 中。这样,即使在 setTimeout 触发下一次更新之前用户刷新了页面,最新的 qty 值也已经被保存。
  3. 重置功能:

    • resetBtn.addEventListener('click', ...) 监听重置按钮的点击事件
    • localStorage.removeItem('saved_countdown'); 从 localStorage 中删除保存的倒计时值。
    • location.reload(); 刷新页面。由于 localStorage 中的值已被移除,页面重新加载时,倒计时将从 defaultQty(即 57)重新开始。
  4. 随机性:

    • Math.floor((Math.random() * 3) + 1) 生成一个 1 到 3 之间的随机整数,作为每次减少的数量。
    • Math.floor(((Math.random() * 15) + 15) * 1000) 生成一个 15 到 30 秒之间的随机延迟时间。这种随机性使得倒计时看起来更自然,模拟了库存或事件的随机波动。
  5. 浏览器兼容性:

    • localStorage 在现代浏览器中普遍支持。
    • 空值合并运算符 ?? 是ES2020特性,如果需要支持旧版浏览器,可以使用 defaultQty = localStorage.getItem('saved_countdown') !== null ? localStorage.getItem('saved_countdown') : 57; 这样的传统写法。

总结

通过巧妙地结合 localStorage 和递归的 setTimeout 函数,我们成功地创建了一个在页面刷新后依然能保持其状态的 JavaScript 倒计时。这种模式不仅适用于倒计时,也可以推广到任何需要在客户端持久化状态的场景,例如用户设置、购物车内容等。理解 localStorage 的工作原理及其在状态管理中的应用,是构建健壮和用户友好型Web应用的关键技能之一。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

236

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

458

2024.03.01

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

232

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

87

2025.10.17

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

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

299

2023.08.03

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

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

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

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

精品课程

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

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

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

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