freeCodeCamp/guide/chinese/html/html5-web-storage/index.md

54 lines
1.5 KiB
Markdown
Raw Normal View History

---
title: HTML5 Web Storage
localeTitle: HTML5网络存储
---
## HTML5网络存储
Web存储允许Web应用程序在每个源每个域和协议的浏览器存储中存储多达5MB的信息。
### Web存储的类型
有两个对象用于在客户端上存储数据:
`window.localStorage` :存储没有过期日期的数据,直到删除为止。
```javascript
// Store Item
localStorage.setItem("foo", "bar");
// Get Item
localStorage.getItem("foo"); //returns "bar"
```
`window.sessionStorage` :存储一个会话的数据,当浏览器/浏览器选项卡关闭时,数据会丢失。
```javascript
// Store Item
sessionStorage.setItem("foo", "bar");
// Get Item
sessionStorage.getItem("foo"); //returns "bar"
```
由于当前实现仅支持字符串到字符串映射,因此需要序列化和反序列化其他数据结构。
您可以使用JSON.stringify和JSON.parse来完成此操作。
例如对于给定的JSON
```
var jsonObject = { 'one': 1, 'two': 2, 'three': 3 };
```
我们首先将JSON对象转换为字符串并保存在本地存储中
```
localStorage.setItem('jsonObjectString', JSON.stringify(jsonObject));
```
要从存储在本地存储中的字符串中获取JSON对象
```
var jsonObject = JSON.parse(localStorage.getItem('jsonObjectString'));
```
#### 更多信息:
[MDN](https://developer.mozilla.org/en-US/docs/Web/API/Window/localStorage) [HTML5 Rocks](https://www.html5rocks.com/en/features/storage) [W3学校](https://www.w3schools.com/html/html5_webstorage.asp)