HTML中LocalStorage详解

存值

	var user={"name":"zhangsan","age":18};
    function save(){
        localStorage.setItem("user",JSON.stringify(user));
        console.log("保存成功");
    }

取值

	function findUser(){
        alert(localStorage.getItem("user"));
    }

删除

	function removeUser() {
        localStorage.removeItem("user");
        console.log("删除成功");
    }

修改

	function updateUser() {
        user.age++;
        localStorage.setItem("user",JSON.stringify(user));
        console.log("修改成功");
    }

storage事件

监听storage事件 一旦有localStorage发生改变 就会触发;

页面1:

	<script>
        window.addEventListener("storage",function (data) {
            console.log(data);
        });
    </script>

页面2:

<body>
    <div onclick="localStorageUpdate()">修改localStorage</div>
</body>
    <script>
        function localStorageUpdate(){
            localStorage.setItem("user","张三2");
            console.log("修改成功");
        }
    </script>

为LocalStorage设置时间

localStorage原生是不支持设置过期时间的,想要设置的话,我们可以自己来封装一层逻辑

	function setTimelocalStorage(key,value) {
        var cutime=new Date().getTime();
        localStorage.setItem(key,JSON.stringify({val:value,time:cutime}));
    }
    function getTimelocalStorage(key,exp) { //exp 是设置的过期时间
        var dataobj =JSON.parse(localStorage.getItem(key));
        if (new Data.getTime()-dataobj.time>=exp){
            console.log("过期");
        }else{}
    }

原理:
存值的时候存附带一个设置的时间
取值的时候传一个过期时间(毫秒),和存的时候作比较,然后作相应的操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值