layui通过本地存储数据,实现在其他页面的数据回显,附了解window.localStorae

  • Post author:
  • Post category:其他


在使用前我们先简单了解下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页面,同时数据回显。

在这里插入图片描述



版权声明:本文为qq_41486333原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。