离线数据存储

页面中可能会有这种需求,一个文本框,刷新或者浏览器重启之后,里面的内容仍然保留着。传统的cookie因为其容量有限,难以满足要求。考虑到现代浏览器(非IE)一般都是支持html5的,可以利用本地存储的方法实现

 

         localStorage.setItem('key','Hello World');

var value = localStorage.getItem('key');

 

 

IE早期的版本不支持这种方式,但是可以通过另外一种方式来实现:

首先设置一个html元素的style属性:

<div id="dataStore"></div>

通过javascript控制

View Code
//设值
var ds = document.getElementById("dataStore");

ds.setAttribute("val",this.value);

ds.save("BookInfo");





//取值:

var ds = document.getElementById("dataStore");

ds.load("BookInfo");

tt.value=ds.getAttribute("val");



上面的存储方式可以再每个域中存储100k数据

 

下面模拟一下新浪微博发微博的文本框(每次内容更新,但是未提交的时候,都会保存在浏览器上,下次打开该浏览器的时候,内容依然会显示在文本框里):

 

<!DOCTYPE HTML>

<html lang="en">

<head>

<meta charset="GBK">

<title>IE本地数据存储</title>

</head>

<body>



<textarea id="tt" name="" rows="20" cols="100"></textarea>

<div id="dataStore"></div>

<script type="text/javascript">

//取值

(
function(){

var tt = document.getElementById("tt"),

ds
= document.getElementById("dataStore"),

value
= '';

try{

value
= localStorage.getItem('key');

}
catch(error){

ds.load(
"BookInfo");

value
= ds.getAttribute("val");

}

tt.value
= value;

})();

</script>



<script type="text/javascript">

//设值

(
function(){

var tt = document.getElementById("tt"),

ds
= document.getElementById("dataStore");

tt.onchange
= function(){

try{

localStorage.setItem(
'key',this.value);

}
catch(e){

ds.setAttribute(
"key",this.value);

ds.save(
"BookInfo");

}

}

})();

</script>

</body>

</html>



 

转载于:https://www.cnblogs.com/sirzxj/archive/2012/02/11/2347255.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值