客户端存储

1.web存储
web存储有两个我们经常使用的对象,localStorage和sessionStorage,这两个对象实际上是持久化关联数组
web存储特点:容易使用、坚持大容量浏览器(并非不限量),数据存储同时兼容当前所有主流浏览器,但是不兼容早期浏览器
localStorage和sessionStorage在使用方便没什么太大区别,区别在于有效期和作用域
localStorage使用:

localStorage.setItem('name', 'wxn');
localStorage.setItem('age', '18');
for (let i = 0; i < localStorage.length; i++) {
let everyKey = localStorage.key(i);
let value = localStorage.getItem(everyKey);
console.log('everyKey:' + everyKey);
console.log('value:' + value);
}
localStorage.removeItem('name'); //删除 name
localStorage.clear(); //删除全部

注意当前只支持存储字符串类型,所以我们存值和取值时需要手动编码和解码

let data = {
"id": "6384944",
"class": "list-item",
"data-title": "百年孤独",
};
localStorage.setItem('book', JSON.stringify(data));
let book = JSON.parse(localStorage.book);
console.log(book);

上面代码中的使用方法对sessionStorage同样适用,
localStorage 存储的数据是永久性的,除非web应用可以删除存储的数据,或者用户通过设置
浏览器配置来删除,否则数据将一直保留在用户的电脑上,永不过期。同源的文档间可以共享localStorage的数据,甚至可读可写,非同源的文档不共享数据。
sessionStorage 的作用域也是限定在同源文档中,并且,sessionStorage的作用域还被限定在窗口中。如果同源的文档渲染在不同的浏览器标签页中,也是不可共享的,它们分别是两个sessionStorage
localStorage和存储时间都是采用广播机制,浏览器会对目前正在访问的同样站点的所有窗口发送消息

2.cookie存储
一种早期的客户端存储机制,适合存储少量的文本的数据。
cookie存储特点:不论服务器端是否需要,每一次http请求都会把这些数据传输到服务器端。所有新旧浏览器都支持它
cookie的有效期很短暂,只能持续在web浏览器的会话期间,一旦用户关闭浏览器,cookie保存的数据就丢失了。
cookie的作用域默认由文档源限制,可以通过设置cookie的domain设置子域的相互共享
使用:

document.cookie = 'verison='+encodeURIComponent(document.lastModified);

要改变cookie的值需要使用相同的名字、路径和域,但是新的值重新设置cookie的值,同样的,设置新的max-age属性就可以改变原来的cookie的有效期。
要删除一个cookie,需要使用相同的名字、路径和域,然后指定一个任意非空的值,并且将max-age属性指定为0,再次设置cookie
3.IE User Data
IE专属浏览器存储机制,使用不多,不做介绍
4.离线web应用
HTML5 标准中定义了一组“离线web应用”API,用以缓存Web页面以及相关资源(脚本,css文件,图像等)。实现的是web应用整体存储在客户端,而不仅仅是存储数据,哪怕在网络不可用的时候web应用依然是可用的。
关于离线web应用现在很多都在应用,需要考虑到几个问题
应用程序缓存清单:首先创建一个清单包含所有应用程序的所有URL列表,在主页面HTML中配置mainfest属性,指向到该清单文件,该文件必须以CACHE MANIFEST字符串开始,其余就是要缓存的文件URL列表
缓存的更新:可以通过applicationCache.status属性查看当前缓存状态
applicationCache.UNCACHED(0)
应用程序没有设置manifest属性
applicationCache.IDLE(1)
清单文件已经检查完毕,并且已经缓存了最新的应用程序
applicationCache.CHECKING(2)
浏览器正在检查清单文件
applicationCache.DOWNLOADING(3)
浏览器正在下载并缓存清单中列举的所有文件
applicationCache.UPDATEREADY(4)
已经下载和缓存了最新版的应用程序
applicationCache.OBSOLETE(5)
清单文件不存在,缓存将被清除

5.web数据库
很多主流浏览器都开始在继承客户端数据库的功能,但是都因API标准化工作而失败

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,233评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,013评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,030评论 0 241
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,827评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,221评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,542评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,814评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,513评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,225评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,497评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,998评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,342评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,986评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,055评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,812评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,560评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,461评论 2 266