在使用前我们先简单了解下window.localStorae.
localStorage 和 sessionStorage 属性允许在浏览器中存储 key/value 即键值对的形式的数据。
localStorage 会永久保存整个网站的数据,保存的数据不会过期,直到手动去删除,即使关闭页面也会存在。
提示:
如果你只想将数据保存在当前会话中,可以使用 sessionStorage 属性, 该数据对象临时保存同一窗口(或标签页)的数据,在关闭窗口或标签页之后将会删除这些数据。(其实这边存储页面应该用sessionStorage 更为合适,不过当时做的时候没特意了解,便没去使用了,感兴趣的可以去使用下)
使用方法:
存储数据:
localStorage.setItem(“key”, “value”);
获取数据:
var lastname = localStorage.getItem(“key”);
删除指定的数据:
localStorage.removeItem(“key”);
删除所有数据:
localStorage.clear();
localStorage 的优势
1、localStorage 拓展了 cookie 的 4K 限制。
2、localStorage 会可以将第一次请求的数据直接存储到本地,这个相当于一个 5M 大小的针对于前端页面的数据库,相比于 cookie 可以节约带宽,但是这个却是只有在高版本的浏览器中才支持的。
localStorage 的局限
1、浏览器的大小不统一,并且在 IE8 以上的 IE 版本才支持 localStorage 这个属性。
2、目前的浏览器中都会把localStorage的值类型限定为string类型即只支持 string 类型的存储,这个在对日常比较常见的JSON对象类型需要一些转换。
3、localStorage在浏览器的隐私模式下面是不可读取的。
4、localStorage本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡。(所以使用时记得不需要数据时写个删除存储数据的代码,以防忘记手动删除,一直存在,影响页面响应)
5、localStorage不能被爬虫抓取到。
在使用 localStorage 的时候,需要先判断浏览器是否支持 localStorage 这个属性:
if(! window.localStorage){
alert("浏览器不支持localstorage");
return false;
}else{
//主逻辑业务
}
当我们将 JSON存入 localStorage 时, localStorage 会自动将其转换成为字符串形式。
var data={
name:'zhuozhuo',
age:23
};
var str=JSON.stringify(data); //将json转换成json字符串
window.localStorage.setItem("data",str); //将json字符串存入localStorage
var json=window.localStorage.getItem("data"); //将json字符串从localStorage取出
var jsonObj=JSON.parse(json); //将JSON字符串转换成为JSON对象输出
开始实际操作,在一个layui的页面通过window.localStorage本地存储。将在显示的数据表格中,点击该行的编辑,获取的该行数据存入localStorage。
再在另个页面的输入框中实现数据回显。
效果展示:
在此点击id为31的编辑后弹出update页面,同时数据回显。