HTML5 localStorage使用方法及注意点

html5新增了在客户端存储数据的新方法:
1.localStorage - 没有时间限制的数据存储;
2.sessionStorage - 针对一个session的数据存储,当用户关闭浏览器窗口后,数据会被删除。

浏览器支持程度

这里写图片描述

注意到,IE8以及以上版本是支持localStorage和sessionStorage的,但是需要注意的是,IE8-IE10中是需要服务器或者localhost才能使用。

使用方法

localStorage和sessionStorage的使用方法是一致的,区别在于:
localStorage方法存储的数据没有时间限制。第二天、第二周或下一年之后,数据依然可用。
sessionStorage 方法针对一个 session 进行数据存储。当用户关闭浏览器窗口后,数据会被删除。
创建localStorage

localStorage.setItem('user','轮回韩');

localStorage.user='轮回韩';

访问localStorage

localStorage.getItem('user','轮回韩');      //与localStorage.setItem对应

localStorage.user;       //与设置时localStorage.user='轮回韩'对应

存储数组和对象

localStorage都是以字符串形式来存储数据的,即使你存储的是数组和对象,localStorage也会将数组和对象以字符串的形式存储。

存储对象

var obj={
            name:'轮回韩',
            age:'100',
            sex:'女'
        };
console.log(obj);                  //输出 Object {name: "轮回韩", age: "100", sex: "女"}
console.log(typeof obj);           //输出 object 

window.localStorage.setItem('people',obj);

console.log(window.localStorage.getItem('people'));           //输出 [object Object]                                                     
console.log(typeof window.localStorage.getItem('people'));    //输出 string

存储数组

var arr=[2,3,5];
console.log(arr);               //输出 [2, 3, 5]                       
console.log(typeof arr);        //输出 object

window.localStorage.setItem('num',arr);

console.log(window.localStorage.getItem('num'));              //输出 2,3,5
console.log(typeof window.localStorage.getItem('num'));       //输出 string

解决办法
其实大多时候我们想要存储的就是数组和对象,这时候该怎么办呢?
解决办法就是存储的时候用JSON.stringify转换后再存储,获取的时候用JSON.parse()转换后再获取。

 var obj={
            name:'轮回韩',
            age:'100',
            sex:'女'
        };
console.log(obj);          //Object {name: "轮回韩", age: "100", sex: "女"}
console.log(typeof obj);   //object

window.localStorage.setItem('people',JSON.stringify(obj));

console.log(JSON.parse(window.localStorage.getItem('people')));        //Object {name: "轮回韩", age: "100", sex: "女"}
console.log(typeof JSON.parse(window.localStorage.getItem('people'))); //object
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值