前端: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,提供类似于多页面导航的体验。

相关推荐
高山我梦口香糖35 分钟前
[react]searchParams转普通对象
开发语言·前端·javascript
m0_7482352438 分钟前
前端实现获取后端返回的文件流并下载
前端·状态模式
m0_748240251 小时前
前端如何检测用户登录状态是否过期
前端
black^sugar2 小时前
纯前端实现更新检测
开发语言·前端·javascript
寻找沙漠的人2 小时前
前端知识补充—CSS
前端·css
GISer_Jing2 小时前
2025前端面试热门题目——计算机网络篇
前端·计算机网络·面试
m0_748245522 小时前
吉利前端、AI面试
前端·面试·职场和发展
理想不理想v3 小时前
webpack最基础的配置
前端·webpack·node.js
pubuzhixing3 小时前
开源白板新方案:Plait 同时支持 Angular 和 React 啦!
前端·开源·github
2401_857600953 小时前
SSM 与 Vue 共筑电脑测评系统:精准洞察电脑世界
前端·javascript·vue.js