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

localStorage

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

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

存储数据

javascript 复制代码
localStorage.setItem('key', 'value');

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

读取数据

javascript 复制代码
const value = localStorage.getItem('key');

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

删除数据

javascript 复制代码
localStorage.removeItem('key');

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

清除所有数据

javascript 复制代码
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,提供类似于多页面导航的体验。

相关推荐
良木林22 分钟前
JavaScript书写基础和基本数据类型
开发语言·前端·javascript
brzhang7 小时前
我操,终于有人把 AI 大佬们 PUA 程序员的套路给讲明白了!
前端·后端·架构
止观止7 小时前
React虚拟DOM的进化之路
前端·react.js·前端框架·reactjs·react
goms8 小时前
前端项目集成lint-staged
前端·vue·lint-staged
谢尔登8 小时前
【React Natve】NetworkError 和 TouchableOpacity 组件
前端·react.js·前端框架
Lin Hsüeh-ch'in8 小时前
如何彻底禁用 Chrome 自动更新
前端·chrome
augenstern41610 小时前
HTML面试题
前端·html
张可10 小时前
一个KMP/CMP项目的组织结构和集成方式
android·前端·kotlin
G等你下课10 小时前
React 路由懒加载入门:提升首屏性能的第一步
前端·react.js·前端框架
蓝婷儿11 小时前
每天一个前端小知识 Day 27 - WebGL / WebGPU 数据可视化引擎设计与实践
前端·信息可视化·webgl