博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js本地存储解决方案(localStorage与userData)
阅读量:7192 次
发布时间:2019-06-29

本文共 3120 字,大约阅读时间需要 10 分钟。

WEB应用的快速发展,是的本地存储一些数据也成为一种重要的需求,实现的方案也有很多,最普通的就是cookie了,大家也经常都用,但是cookie的缺点是显而易见的,其他的方案比如:IE6以上的userData,Firefox下面的globalStorage,以及Flash的本地存储,除了Flash之外,其他的几个都有一些兼容性的问题。

 

sessionStorage与localStorage

Web Storage实际上由两部分组成:sessionStorage与localStorage。

sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后数据也随之销毁。因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储。

localStorage用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的。

 

userData

 

语法:

XML <Prefix: CustomTag ID=sID STYLE="behavior:url('#default#userData')" />

HTML <ELEMENT STYLE="behavior:url('#default#userData')" ID=sID>

Scripting object .style.behavior = "url('#default#userData')"

object .addBehavior ("#default#userData")

 

 

属性:

expires 设置或者获取 userData behavior 保存数据的失效日期。

XMLDocument 获取 XML 的引用。

 

方法:

getAttribute() 获取指定的属性值。

load(object) 从 userData 存储区载入存储的对象数据。

removeAttribute() 移除对象的指定属性。

save(object) 将对象数据存储到一个 userData 存储区。

setAttribute() 设置指定的属性值。

 

 

localStorage

方法:

 

localStorage.getItem(key):获取指定key本地存储的值

localStorage.setItem(key,value):将value存储到key字段

localStorage.removeItem(key):删除指定key本地存储的值

封装

localData = {        hname:location.hostname?location.hostname:'localStatus',        isLocalStorage:window.localStorage?true:false,        dataDom:null,        initDom:function(){ //初始化userData            if(!this.dataDom){                try{                    this.dataDom = document.createElement('input');//这里使用hidden的input元素                    this.dataDom.type = 'hidden';                    this.dataDom.style.display = "none";                    this.dataDom.addBehavior('#default#userData');//这是userData的语法                    document.body.appendChild(this.dataDom);                    var exDate = new Date();                    exDate = exDate.getDate()+30;                    this.dataDom.expires = exDate.toUTCString();//设定过期时间                }catch(ex){                    return false;                }            }            return true;        },        set:function(key,value){            if(this.isLocalStorage){                window.localStorage.setItem(key,value);            }else{                if(this.initDom()){                    this.dataDom.load(this.hname);                    this.dataDom.setAttribute(key,value);                    this.dataDom.save(this.hname)                }            }        },        get:function(key){            if(this.isLocalStorage){                return window.localStorage.getItem(key);            }else{                if(this.initDom()){                    this.dataDom.load(this.hname);                    return this.dataDom.getAttribute(key);                }            }        },        remove:function(key){            if(this.isLocalStorage){                localStorage.removeItem(key);            }else{                if(this.initDom()){                    this.dataDom.load(this.hname);                    this.dataDom.removeAttribute(key);                    this.dataDom.save(this.hname)                }            }        }    }

本篇文章转自 http://www.cnblogs.com/beiyuu/archive/2011/07/20/js-localstorage-userdata.html

转载于:https://www.cnblogs.com/sandraMaying/p/js_localStorage_userData.html

你可能感兴趣的文章
PHP+Mysql 实现数据库增删改查
查看>>
Trick
查看>>
Python多继承解析顺序的C3线性算法流程解析
查看>>
2018CCPC 吉林现场赛 赛后总结
查看>>
JavaScript快速入门
查看>>
java CPU 100% 排查
查看>>
UVA494 Kindergarten Counting Game
查看>>
图解设计模式-Singleton模式
查看>>
js中的事件:
查看>>
MVC5-3 Result分析
查看>>
组织行为学笔记(2)——态度和工作满意度
查看>>
小白Python路上第一个难点,也是一个比较重要的点(闭包,迭代器,生成器)...
查看>>
HUT-XXXX 数学
查看>>
Java IO6 :IO总结
查看>>
Spring Data之Hello World
查看>>
python编程基础之三十一
查看>>
JVM入门到放弃之基本概念
查看>>
2017ACM-ICPC 青岛 K.Our Journey of Xian Ends
查看>>
只读变量
查看>>
常用正则表达式,亲测有效
查看>>