We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
javaScript本地缓存的方法我们主要讲述以下四种:
javaScript
Cookie,类型为「小型文本文件」,指某些网站为了辨别用户身份而储存在用户本地终端上的数据。是为了解决 HTTP 无状态导致的问题
Cookie
HTTP
作为一段一般不超过 4KB 的小型文本数据,它由一个名称(Name)、一个值(Value)和其它几个用于控制 cookie 有效期、安全性、使用范围的可选属性组成
cookie
但是cookie在每次请求中都会被发送,如果不使用 HTTPS 并对其加密,其保存的信息很容易被窃取,导致安全风险。举个例子,在一些使用 cookie 保持登录态的网站上,如果 cookie 被窃取,他人很容易利用你的 cookie 来假扮成你登录网站
HTTPS
关于cookie常用的属性如下:
Expires=Wed, 21 Oct 2015 07:28:00 GMT
Expires
Max-Age=604800
Domain
Path
URL
Path=/docs # /docs/Web/ 下的资源会带 Cookie 首部
Secure
通过上述,我们可以看到cookie又开始的作用并不是为了缓存而设计出来,只是借用了cookie的特性实现缓存
关于cookie的使用如下:
document.cookie = '名字=值';
关于cookie的修改,首先要确定domain和path属性都是相同的才可以,其中有一个不同得时候都会创建出一个新的cookie
domain
path
Set-Cookie:name=aa; domain=aa.net; path=/ # 服务端设置 document.cookie =name=bb; domain=aa.net; path=/ # 客户端设置
最后cookie的删除,最常用的方法就是给cookie设置一个过期的事件,这样cookie过期后会被浏览器删除
HTML5新方法,IE8及以上浏览器都兼容
HTML5
localStorage
storage
下面再看看关于localStorage的使用
设置
localStorage.setItem('username','cfangxu');
获取
localStorage.getItem('username')
获取键名
localStorage.key(0) //获取第一个键名
删除
localStorage.removeItem('username')
一次性清除所有存储
localStorage.clear()
localStorage 也不是完美的,它有两个缺点:
localStorage.setItem('key', {name: 'value'}); console.log(localStorage.getItem('key')); // '[object, Object]'
sessionStorage 和 localStorage 使用方法基本一致,唯一不同的是生命周期,一旦页面(会话)关闭,sessionStorage 将会删除数据
sessionStorage
indexedDB 是一种低级API,用于客户端存储大量结构化数据(包括, 文件/ blobs)。该API使用索引来实现对该数据的高性能搜索
indexedDB
虽然 Web Storage 对于存储较少量的数据很有用,但对于存储更大量的结构化数据来说,这种方法不太有用。IndexedDB提供了一个解决方案
Web Storage
IndexedDB
LocalStorage
JS
关于indexedDB的使用基本使用步骤如下:
打开数据库并且开始一个事务
创建一个 object store
object store
构建一个请求来执行一些数据库操作,像增加或提取数据等。
通过监听正确类型的 DOM 事件以等待操作完成。
DOM
在操作结果上进行一些操作(可以在 request 对象中找到)
request
关于使用indexdb的使用会比较繁琐,大家可以通过使用Godb.js库进行缓存,最大化的降低操作难度
indexdb
Godb.js
关于cookie、sessionStorage、localStorage三者的区别主要如下:
存储大小: cookie数据大小不能超过4k,sessionStorage和localStorage 虽然也有存储大小的限制,但比cookie大得多,可以达到5M或更大
4k
有效时间:localStorage 存储持久数据,浏览器关闭后数据不丢失除非主动删除数据; sessionStorage 数据在当前浏览器窗口关闭后自动删除;cookie设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭
数据与服务器之间的交互方式, cookie的数据会自动的传递到服务器,服务器端也可以写cookie到客户端; sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存
在了解了上述的前端的缓存方式后,我们可以看看针对不对场景的使用选择:
The text was updated successfully, but these errors were encountered:
要注意的一点是,即便是同一页面同源,sessionStorage也是不能互相访问的,存在浏览器隔离
Sorry, something went wrong.
No branches or pull requests
一、方式
javaScript
本地缓存的方法我们主要讲述以下四种:cookie
Cookie
,类型为「小型文本文件」,指某些网站为了辨别用户身份而储存在用户本地终端上的数据。是为了解决HTTP
无状态导致的问题作为一段一般不超过 4KB 的小型文本数据,它由一个名称(Name)、一个值(Value)和其它几个用于控制
cookie
有效期、安全性、使用范围的可选属性组成但是
cookie
在每次请求中都会被发送,如果不使用HTTPS
并对其加密,其保存的信息很容易被窃取,导致安全风险。举个例子,在一些使用cookie
保持登录态的网站上,如果cookie
被窃取,他人很容易利用你的cookie
来假扮成你登录网站关于
cookie
常用的属性如下:Expires
高)Domain
指定了Cookie
可以送达的主机名Path
指定了一个URL
路径,这个路径必须出现在要请求的资源的路径中才可以发送Cookie
首部Secure
的Cookie
只应通过被HTTPS
协议加密过的请求发送给服务端通过上述,我们可以看到
cookie
又开始的作用并不是为了缓存而设计出来,只是借用了cookie
的特性实现缓存关于
cookie
的使用如下:关于
cookie
的修改,首先要确定domain
和path
属性都是相同的才可以,其中有一个不同得时候都会创建出一个新的cookie
最后
cookie
的删除,最常用的方法就是给cookie
设置一个过期的事件,这样cookie
过期后会被浏览器删除localStorage
HTML5
新方法,IE8及以上浏览器都兼容特点
localStorage
的时候,本页面不会触发storage
事件,但是别的页面会触发storage
事件。localStorage
本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡下面再看看关于
localStorage
的使用设置
获取
获取键名
删除
一次性清除所有存储
localStorage
也不是完美的,它有两个缺点:Cookie
一样设置过期时间sessionStorage
sessionStorage
和localStorage
使用方法基本一致,唯一不同的是生命周期,一旦页面(会话)关闭,sessionStorage
将会删除数据扩展的前端存储方式
indexedDB
是一种低级API,用于客户端存储大量结构化数据(包括, 文件/ blobs)。该API使用索引来实现对该数据的高性能搜索虽然
Web Storage
对于存储较少量的数据很有用,但对于存储更大量的结构化数据来说,这种方法不太有用。IndexedDB
提供了一个解决方案优点:
LocalStorage
同步操作性能更高,尤其是数据量较大时JS
的对象缺点:
关于
indexedDB
的使用基本使用步骤如下:打开数据库并且开始一个事务
创建一个
object store
构建一个请求来执行一些数据库操作,像增加或提取数据等。
通过监听正确类型的
DOM
事件以等待操作完成。在操作结果上进行一些操作(可以在
request
对象中找到)关于使用
indexdb
的使用会比较繁琐,大家可以通过使用Godb.js
库进行缓存,最大化的降低操作难度二、区别
关于
cookie
、sessionStorage
、localStorage
三者的区别主要如下:存储大小:
cookie
数据大小不能超过4k
,sessionStorage
和localStorage
虽然也有存储大小的限制,但比cookie
大得多,可以达到5M或更大有效时间:
localStorage
存储持久数据,浏览器关闭后数据不丢失除非主动删除数据;sessionStorage
数据在当前浏览器窗口关闭后自动删除;cookie
设置的cookie
过期时间之前一直有效,即使窗口或浏览器关闭数据与服务器之间的交互方式,
cookie
的数据会自动的传递到服务器,服务器端也可以写cookie
到客户端;sessionStorage
和localStorage
不会自动把数据发给服务器,仅在本地保存三、应用场景
在了解了上述的前端的缓存方式后,我们可以看看针对不对场景的使用选择:
cookie
localStorage
sessionStorage
indexedDB
相关连接
The text was updated successfully, but these errors were encountered: