【前端储存】之localStrage、sessionStrage和Vuex

简介

什么是localStrage

localStorage (本地存储) 是一种在用户浏览器中存储数据的客户端存储方式,允许网站将键值对数据持久保存在用户的本地浏览器中 。存储的数据不受浏览器关闭的影响,可以在不同会话和浏览器关闭后仍然保持有效。

  • 生命周期永久有效,除非手动删除,否则关闭页面也会存在

  • 可以多窗口(页面)共享(同一浏览器可以共享)

  • 以键值对的形式存储使用

  • 各浏览器支持的localStorage容量上限不同;一般上限为5MB

  • localStorage.getItem('key'); 如果key不存在则返回null,而不是 undefined
    例:标准的json对象{"name":"john"}

    //设置localStorage保存到本地,第一个为变量名,第二个是值
    localStorage.setItem('username', '安琪拉')

    // 获取数据
    localStorage.getItem('username')

    // 删除保存的数据
    localStorage.removeItem('username')

    // 清除所有保存的数据
    localStorage.clear()

什么是sessionStrage

sessionStorage 是一种在用户浏览器中临时存储数据的客户端存储方式适用于同一浏览器窗口或标签的会话期间。存储的数据在用户关闭浏览器窗口或标签时会被清除,因此适用于保存会话相关的临时信息,例如用户登录状态、暂时的用户选项等。

注:

  • 【只在本地存储】:seesionStorage的数据不会跟随HTTP请求一起发送到服务器,只会在本地生效,并在关闭标签页后清除数据。

  • 【存储方式】:seesionStorage的存储方式采用key、value的方式。value的值必须为字符串类型

  • 【存储上限限制】:不同的浏览器存储的上限也不一样,但大多数浏览器把上限限制在5MB以下

    // 设置sessionStorage保存到本地,第一个为变量名,第二个是值
    sessionStorage.setItem('sessionName', '可乐')

    // 获取数据
    sessionStorage.getItem('sessionName')

    // 删除保存的数据
    sessionStorage.removeItem('sessionName')

    // 清除所有保存的数据
    sessionStorage.clear()

什么是Vuex

Vuex 是一个用于 Vue.js 应用程序的状态管理模式和库。它专门用于管理应用程序中的状态(数据),使得不同组件之间可以共享和交流数据,而无需通过传递 props 或事件来传递数据。

注:详细介绍见: Vuex的原理和使用方法

扩展

  • JSON.stringify(); // 将json格式的数据(JavaScript 对象)转换成JSON格式的字符串
  • JSON.parse(); //将JSON格式的字符串转换成JSON对象进行处理

三者区别

主要区别

localStorage:是通过本地数据存储的,以文件的方式存储在本地;

sessionStorage:只是本地存储一个会话中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后也随之销毁;

Vuex:是一个全局状态数据管理,存储在内存中,没有内存大小限制;是专门为vue.js应用程序开发的状态管理模式;通过采用集中式存储管理应用的所有组件的状态。

应用场景

localStorage:一般用于跨页面传递数据场景;长期性保存的数据;

sessionStorage:适用于单页应用程序,方便再各业务模块进行传值;

也用于敏感账号的一次性登录,关闭当时页面再次打开时会需要重新登录

Vuex:是专门为vue.js应用程序开发的状态管理模式;用于组件之间传值

存储永久性

localStorage窗口或浏览器关闭也始终有效;

sessionStorage仅在当前浏览器关闭前有效;

vuex在刷新页面时存储的值就会丢失

相关推荐
烛阴4 分钟前
C# 正则表达式(3):分组与捕获——从子串提取到命名分组
前端·正则表达式·c#
一 乐20 分钟前
校园实验室|基于springboot + vue校园实验室管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
eason_fan1 小时前
从一则内存快照看iframe泄漏:活跃与Detached状态的回收差异
前端·性能优化
狗头大军之江苏分军1 小时前
年底科技大考:2025 中国前端工程师的 AI 辅助工具实战盘点
java·前端·后端
一 乐2 小时前
酒店客房预订|基于springboot + vue酒店客房预订系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
编程修仙2 小时前
第三篇 Vue路由
前端·javascript·vue.js
比老马还六2 小时前
Bipes项目二次开发/硬件编程-设备连接(七)
前端·javascript
掘金一周2 小时前
前端一行代码生成数千页PDF,dompdf.js新增分页功能| 掘金一周 12.25
前端·javascript·后端
张就是我1065923 小时前
漏洞复现指南:利用 phpinfo() 绕过 HttpOnly Cookie 保护
前端
Kagol3 小时前
🎉TinyVue v3.27.0 正式发布:增加 Space 新组件,ColorPicker 组件支持线性渐变
前端·vue.js·typescript