localStroage的用法

Cookie

每个域名存储量比较小(各浏览器不同,大致4K)
所有域名的存储量有限制(各浏览器不同,大致4K)
有个数限制(各浏览器不同)
会随请求发送到服务器

LocalStorage

永久存储
单个域名存储量比较大(推荐5MB,各浏览器不同)
总体数量无限制
浏览器关闭不清除。页面之间可以实现共享。同一域名下实现共享
只要不清除。可以在本地永久储存。

SessionStorage

只在 Session 内有效
存储量更大(推荐没有限制,但是实际上各浏览器也不同)
浏览器关闭则清除。不同的窗口之间不能共享。同一域名下实现共享

三者异同点:
特性CookielocalStoragesessionStorage
数据的生命期一般由服务器生成,可设置失效时间。如果在浏览器端生成Cookie,默认是关闭浏览器后失效除非被清除,否则永久保存仅在当前会话下有效,关闭页面或浏览器后被清除
存放数据大小4K左右一般为5MB
与服务器端通信每次都会携带在HTTP头中,如果使用cookie保存过多数据会带来性能问题仅在客户端(即浏览器)中保存,不参与和服务器的通信
易用性需要程序员自己封装,源生的Cookie接口不友好源生接口可以接受,亦可再次封装来对Object和Array有更好的支持

示例代码一:
var body = document.body;
        var pcolor = document.querySelector('p');
        var clear = document.querySelector('#clear');

        var bgcolorForm = document.querySelector('#bgcolor');
        var colorFrom = document.querySelector('#fcolor');

        if(!localStorage.getItem('bgcolor')){
            populateStorage();
        }else{
            setStyle();
        }

        function populateStorage(){
            localStorage.setItem('bgcolor',bgcolorForm.value);
            localStorage.setItem('color',colorFrom.value);
            setStyle();
        }
        function setStyle(){
            var currentBgColor = localStorage.getItem('bgcolor');
            var currentColor = localStorage.getItem('color');

            bgcolorForm.value = currentBgColor;
            colorFrom.value = currentColor;

            body.style.backgroundColor = currentBgColor;
            pcolor.style.color = currentColor;
        }
        function clearFn(){
            localStorage.clear();
        }
        bgcolorForm.addEventListener('change',populateStorage,false);
        colorFrom.addEventListener('change',populateStorage,false);
        clear.addEventListener('click',clearFn,false);

 

示例代码二:

function unlock(i, station_name_cn, station_name_en) {
        var locking = localStorage.getItem('lock');
        if (locking && locking == 1) {
            localStorage.setItem("lock", i);
            // console.log(localStorage.getItem('lock'));
            window.location.href = 'unlock.html?' + station_name_cn + '-' + station_name_en;
        }
    }

if (station_id > 1) {
            if (!localStorage.getItem('lock') || localStorage.getItem('lock') != station_id) {
                localStorage.setItem("lock", 1);
            }
            // unlock(station_id,station_name_cn,station_name_en);
        }

 

参考资料:

MDN:https://developer.mozilla.org/zh-CN/docs/Web/API/Web_Storage_API

详说 Cookie, LocalStorage 与 SessionStorage

HTML5本地存储localStorage和sessionStorage…

js对cookie的操作…

 

转载于:https://www.cnblogs.com/qianduanjingying/p/5885843.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值