0

0

js 怎么实现本地存储

煙雲

煙雲

发布时间:2025-08-25 14:17:01

|

454人浏览过

|

来源于php中文网

原创

选择 localstorage 还是 sessionstorage 取决于数据生命周期需求,localstorage 用于长期保存如用户偏好设置,sessionstorage 用于会话期间临时存储如购物车信息;2. 本地存储限制包括:每域名约 5mb 容量、仅支持字符串类型需用 json.stringify/parse 转换、同步操作可能阻塞主线程;3. 兼容性处理可通过检测 window.localstorage 是否存在,若不支持则降级使用 cookie 或引入 store.js 等库自动适配;4. 安全性方面,本地存储易受用户篡改和 xss 攻击,不应存储敏感信息如密码,必要时应加密并加强 xss 防护;5. 清理本地存储可调用 localstorage.clear() 清空所有数据或 removeitem('key') 删除指定键,也可通过封装 setitemwithexpiry 和 getitemwithexpiry 方法实现带过期时间的自动清理机制;6. 跨域访问受同源策略限制,不同域名无法直接共享本地存储,可通过 postmessage 实现窗口间通信或使用 cors 配合服务器端授权进行数据共享,具体选择依据是共享范围和系统复杂度。

js 怎么实现本地存储

在 JavaScript 中,实现本地存储主要依赖于

localStorage
sessionStorage
这两个 Web API。它们允许你在用户的浏览器中存储键值对,即使关闭浏览器后,
localStorage
中的数据仍然存在,而
sessionStorage
中的数据则会在会话结束后被清除。

localStorage 和 sessionStorage 都是 window 对象的属性,使用起来非常简单。

localStorage.setItem('key', 'value') 用于存储数据,localStorage.getItem('key') 用于读取数据,localStorage.removeItem('key') 用于删除数据,localStorage.clear() 用于清空所有数据。

sessionStorage 的用法与 localStorage 完全相同,区别在于数据的生命周期。

如何选择 localStorage 和 sessionStorage?

选择

localStorage
还是
sessionStorage
取决于你的需求。如果需要长期保存数据,例如用户的偏好设置,那么
localStorage
是一个不错的选择。如果只是需要在当前会话中保存数据,例如购物车信息,那么
sessionStorage
更合适。

当然,你也可以根据实际情况,将两者结合使用。例如,使用

localStorage
保存用户的登录状态,使用
sessionStorage
保存用户的临时操作数据。

本地存储有哪些限制?

虽然本地存储很方便,但也有一些限制需要注意。

首先,存储容量有限制。一般来说,每个域名下

localStorage
sessionStorage
的存储容量都在 5MB 左右。不同的浏览器可能会有所差异,但通常不会超过这个范围。因此,不适合存储大量数据。

其次,本地存储只能存储字符串类型的数据。如果要存储其他类型的数据,例如对象或数组,需要先将其转换为字符串,然后再存储。读取数据时,再将其转换回原来的类型。通常可以使用

JSON.stringify()
JSON.parse()
方法来实现这个转换。

另外,本地存储是同步操作。这意味着在读写数据时,会阻塞 JavaScript 线程。如果存储的数据量较大,可能会导致页面卡顿。因此,建议尽量避免在主线程中进行大量的本地存储操作。

如何处理本地存储的兼容性问题?

虽然现代浏览器都支持

localStorage
sessionStorage
,但为了兼容旧版本的浏览器,可能需要进行一些兼容性处理。

一种常见的做法是,先检测浏览器是否支持

localStorage
sessionStorage
,如果不支持,则使用 Cookie 或其他替代方案。

function supportsLocalStorage() {
  try {
    return 'localStorage' in window && window['localStorage'] !== null;
  } catch (e) {
    return false;
  }
}

if (supportsLocalStorage()) {
  // 使用 localStorage
} else {
  // 使用 Cookie 或其他替代方案
}

另一种做法是,使用一些现成的库,例如

store.js
,它会自动检测浏览器是否支持
localStorage
sessionStorage
,如果不支持,则使用其他替代方案。

本地存储安全性如何?

本地存储的数据存储在用户的浏览器中,因此存在一定的安全风险。

首先,本地存储的数据可以被用户修改。这意味着用户可以篡改你存储的数据,从而影响你的应用程序的正常运行。

其次,本地存储的数据可能会被恶意网站窃取。如果你的网站存在 XSS 漏洞,攻击者可以通过 JavaScript 代码读取你存储在

localStorage
sessionStorage
中的数据。

因此,不建议在本地存储中存储敏感信息,例如用户的密码或信用卡信息。如果必须存储敏感信息,应该对其进行加密处理。

陌言AI
陌言AI

陌言AI是一个一站式AI创作平台,支持在线AI写作,AI对话,AI绘画等功能

下载

另外,应该注意防范 XSS 攻击,避免恶意代码读取本地存储的数据。

示例代码:使用 localStorage 存储和读取用户信息

以下是一个简单的示例,演示如何使用

localStorage
存储和读取用户信息。

// 存储用户信息
function saveUserInfo(username, email) {
  const userInfo = {
    username: username,
    email: email
  };
  localStorage.setItem('userInfo', JSON.stringify(userInfo));
}

// 读取用户信息
function getUserInfo() {
  const userInfoStr = localStorage.getItem('userInfo');
  if (userInfoStr) {
    return JSON.parse(userInfoStr);
  } else {
    return null;
  }
}

// 示例用法
saveUserInfo('JohnDoe', 'john.doe@example.com');
const userInfo = getUserInfo();
if (userInfo) {
  console.log('Username:', userInfo.username);
  console.log('Email:', userInfo.email);
} else {
  console.log('No user info found.');
}

这段代码首先定义了两个函数:

saveUserInfo
getUserInfo
saveUserInfo
函数用于存储用户信息,它接受用户名和邮箱地址作为参数,并将它们存储在
localStorage
中,键名为
userInfo
getUserInfo
函数用于读取用户信息,它从
localStorage
中读取键名为
userInfo
的数据,并将其解析为 JavaScript 对象。

然后,代码演示了如何使用这两个函数。首先,调用

saveUserInfo
函数存储用户信息。然后,调用
getUserInfo
函数读取用户信息,并将用户信息打印到控制台。

这个示例演示了如何使用

localStorage
存储和读取简单的 JavaScript 对象。你可以根据自己的需求,修改这段代码,存储和读取其他类型的数据。

如何清理本地存储?

清理本地存储有多种方式。

最简单的方式是使用

localStorage.clear()
方法,它可以清空所有存储在
localStorage
中的数据。

localStorage.clear();

另一种方式是使用

localStorage.removeItem('key')
方法,它可以删除指定键名的数据。

localStorage.removeItem('userInfo');

还可以通过设置过期时间来自动清理本地存储的数据。但

localStorage
本身并不支持设置过期时间。你需要自己实现这个功能。一种常见的做法是,在存储数据时,同时存储一个时间戳,表示数据的过期时间。在读取数据时,先检查当前时间是否超过了过期时间,如果超过了,则删除数据。

function setItemWithExpiry(key, value, expiry) {
  const now = new Date();
  const item = {
    value: value,
    expiry: now.getTime() + expiry,
  };
  localStorage.setItem(key, JSON.stringify(item));
}

function getItemWithExpiry(key) {
  const itemStr = localStorage.getItem(key);
  if (!itemStr) {
    return null;
  }

  const item = JSON.parse(itemStr);
  const now = new Date();

  if (now.getTime() > item.expiry) {
    localStorage.removeItem(key);
    return null;
  }

  return item.value;
}

// 示例用法:存储数据,过期时间为 1 小时
setItemWithExpiry('myKey', 'myValue', 3600000);

// 读取数据
const myValue = getItemWithExpiry('myKey');
if (myValue) {
  console.log('Value:', myValue);
} else {
  console.log('Key not found or expired.');
}

这段代码定义了两个函数:

setItemWithExpiry
getItemWithExpiry
setItemWithExpiry
函数用于存储数据,它接受键名、值和过期时间作为参数。它将值和过期时间存储在一个对象中,并将该对象转换为 JSON 字符串,然后存储在
localStorage
中。
getItemWithExpiry
函数用于读取数据,它从
localStorage
中读取数据,并检查是否已过期。如果已过期,则删除数据并返回
null
。否则,返回数据的值。

这个示例演示了如何使用过期时间来自动清理本地存储的数据。你可以根据自己的需求,修改这段代码,设置不同的过期时间。

如何处理跨域访问本地存储的问题?

由于浏览器的同源策略,不同域名的网站不能互相访问

localStorage
sessionStorage
中的数据。

如果需要在不同域名的网站之间共享数据,可以使用一些跨域通信技术,例如

postMessage
CORS

postMessage
是一种简单而强大的跨域通信机制。它允许一个窗口向另一个窗口发送消息,而不管它们的域名是否相同。

CORS
是一种更复杂的跨域通信机制。它需要在服务器端进行配置,允许指定的域名访问服务器的资源。

选择哪种跨域通信技术取决于你的需求。如果只需要在两个特定的域名之间共享数据,那么

postMessage
可能更简单。如果需要在多个域名之间共享数据,那么
CORS
可能更合适。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

557

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

394

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

756

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

478

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

1051

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

658

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

554

2023.09.20

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

热门下载

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

精品课程

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

共17课时 | 2.2万人学习

XML教程
XML教程

共142课时 | 5.7万人学习

Webpack4.x---十天技能课堂
Webpack4.x---十天技能课堂

共20课时 | 1.4万人学习

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

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