localStorage和sessionStorage

H5新特性之一:本地存储lacalStoragejavascript

优势:前端

  1.解决了cookie本地存储空间不足的问题(cookie中每条cookie的存储空间为4k),localStorage通常浏览器支持的是5m,视浏览器而定java

  2. localStorage会能够将第一次请求的数据直接存储到本地,这个至关于一个5M大小的针对于前端页面的数据库,相比于cookie能够节约带宽数据库

缺点:数组

  1.不一样浏览器大小不统一,而且在IE8以上的IE版本才支持localStorage这个属性浏览器

  2.全部的浏览器中都会把localStorage的值类型限定为string类型,对JSON对象类型须要一些转换cookie

  3.localStorage在浏览器的隐私模式下面是不可读取的session

  4.localStorage本质上是对字符串的读取,若是存储内容多的话会消耗内存空间,会致使页面变卡spa

  5.localStorage不能被爬虫抓取到对象

区别:localStorage属于永久性存储;sessionStorage当会话结束的时候,其中的键值对会被清空

用法:

  1.清空:

localStorage.clear() // undefined 
localStorage //Storage {length: 0}

  2.存储:

localStorage.setItem("name","caibin") //存储名字为name值为caibin的变量
localStorage.name = "caibin"; // 等价于上面的命令 
localStorage // Storage{name: "caibin", length: 1} 读取数据

  3.读取:

localStorage.getItem("name") //caibin,读取保存在localStorage对象里名为name的变量的值
localStorage.name // "caibin"
localStorage.valueOf() //读取存储在localStorage上的全部数据
localStorage.key(0) // 读取第一条数据的变量名(键值)
//遍历并输出localStorage里存储的名字和值
for(var i=0; i<localStorage.length;i++){
  console.log('localStorage里存储的第'+i+'条数据的名字为:'+localStorage.key(i)+',值为:'+localStorage.getItem(localStorage.key(i)));
}

  4.删除某个变量:

localStorage.removeItem("name"); //undefined
localStorage // Storage {length: 0} 以前保存的name变量从localStorage里删除了

  5.检查localStorage里是否保存某个变量:

localStorage.hasOwnProperty('name') // true
localStorage.hasOwnProperty('sex') // false

  6.将数组转为本地字符串:

var arr = ['aa','bb','cc']; // ["aa","bb","cc"]
localStorage.arr = arr //["aa","bb","cc"]
localStorage.arr.toLocaleString(); // "aa,bb,cc"

  7.将JSON存储到localStorage里:

var students = {
  xiaomin: {
    name: "xiaoming",
    grade: 1
  },
  teemo: {
    name: "teemo",
    grade: 3
  }
}
 
students = JSON.stringify(students); //将JSON转为字符串存到变量里
console.log(students);
localStorage.setItem("students",students);//将变量存到localStorage里
 
var newStudents = localStorage.getItem("students");
newStudents = JSON.parse(students); //转为JSON
console.log(newStudents); // 打印出原先对象
相关文章
相关标签/搜索