当前位置: 首页 > news >正文

前端:localStorage和浏览器的历史记录(History API)

localStorage

localStorage 是浏览器提供的一种本地存储机制,用于在客户端(用户的浏览器)中以键值对的形式存储数据。它具有持久性,即存储的数据不会因为页面关闭、浏览器关闭或系统重启而丢失,除非用户手动清除或通过代码删除。以下是 localStorage 的详细原理和工作机制:

键值对存储localStorage 以键值对的方式存储数据。每个键和值都是字符串类型。即使存储的是对象或数组,也需要先将其转换为字符串(通常使用 JSON.stringify())。

存储数据

localStorage.setItem('key', 'value');

使用 setItem 方法,开发者可以将一个值(value)存储到 localStorage 中,指定的 key 用于以后读取该值。数据将以字符串形式存储。

读取数据

const value = localStorage.getItem('key');

使用 getItem 方法可以根据 key 读取存储在 localStorage 中的值。如果该键不存在,返回 null

删除数据

localStorage.removeItem('key');

使用 removeItem 方法可以删除存储在 localStorage 中的特定 key 及其对应的值。

清除所有数据

localStorage.clear();

clear 方法会清空 localStorage 中的所有数据。

localStorage 常用于以下场景:

  • 用户偏好设置:例如保存用户选择的界面主题、语言设置、布局偏好等。当用户再次访问页面时,这些偏好可以从 localStorage 中读取并应用。
  • 表单数据保存:当用户在填写表单时,可以在输入过程中将数据暂存到 localStorage 中,以防止用户在页面意外关闭或刷新时丢失已填写的数据。
  • 简易缓存:用于存储从服务器获取的数据,使得页面在下次加载时可以更快地显示内容。例如,保存一些用户信息或会话数据以减少 API 调用。
  • 状态管理:在单页面应用(SPA)中,localStorage 可以用来保存用户的登录状态(如身份令牌 token),从而使用户在刷新页面后依然保持登录状态。

浏览器的历史记录(History API) 

History API 是浏览器提供的一组接口,用于操作和管理浏览器的历史记录。常用的操作包括:

  • history.pushState():将一个新的状态对象压入历史堆栈中,不会触发页面刷新。适用于单页应用程序(SPA),允许应用在不重新加载页面的情况下改变 URL。
  • history.replaceState():替换当前堆栈顶端的状态,而不是将新的状态推入堆栈。
  • history.back()history.forward():分别用于回退到上一条记录和前进到下一条记录,模拟浏览器的“后退”和“前进”按钮。
  • 使用 history.pushState() 方法可以在不重新加载页面的情况下改变 URL,并将新的状态推入堆栈中。
  • 当调用 history.back() 时,浏览器会从历史堆栈中弹出最后一个状态,并回到之前的页面。

常用场景:

History API 则用于管理浏览器的导航状态,主要用在单页应用(SPA)中,允许在不重新加载页面的情况下修改 URL,提供类似于多页面导航的体验。

 


http://www.mrgr.cn/news/59144.html

相关文章:

  • Flink-cdc Schema Evolution 详解
  • Ubuntu22.04环境搭建MQTT服务器
  • C++ | Leetcode C++题解之第509题斐波那契数
  • Unity3D LayoutGroup组件详解
  • 【linux】ELKB安装token过期
  • 批量修改YOLO格式的标注类别
  • Springboot 整合 Java DL4J 实现智能客服
  • [Python学习日记-57] 常用模块的练习(答案更新中)
  • 爆破(使用Burp Suite)
  • 使用anaconda3创建Python 虚拟环境
  • C++ 在项目中使用vim
  • 【前端开发入门】JavaScript快速入门--js变量
  • 红黑树(Red-Black Tree)
  • 5.Linux按键驱动-fasync异步通知
  • 《人脸表情识别可解释性研究综述(计算机学报)》
  • 如何在Linux服务器后台训练模型
  • eks节点的网络策略配置机制解析
  • 对角双差速轮AGV的动力学解算
  • 【大数据技术基础 | 实验五】ZooKeeper实验:部署ZooKeeper
  • 028_Comma_Separated_List_in_Matlab中的逗号分割列表
  • 【C++初阶】一文讲通C++内存管理
  • 数据结构与算法分析:你真的理解排序算法吗——桶排序(代码详解)
  • redis高级篇之IO多路复用select方法简介 第174节答疑
  • 基于DDPG算法的股票量化交易
  • 【项目实战】HuggingFace初步实战,使用HF做一些小型任务
  • 如何快速绘制高效的业务架构图(三步完成)