JS前端本地存储信息 localStorage

什么是localstorage

localstorage可以说是对cookie的优化,使用它可以方便在客户端存储数据,并且不会随着HTTP传输

localstorage的使用

localstorage存储对象分为两种:

① sessionStorage

: session即会话的意思,在这里的session是指用户浏览某个网站时,从进入网站到关闭网站这个时间段,session对象的有效期就只有这么长。

② localStorage: 将数据保存在客户端硬件设备上,不管它是什么,意思就是下次打开计算机时候数据还在。

两者区别就是一个作为临时保存,一个长期保存,使用方法基本一致;

sessionStorage:

//      通过setItem()方法保存信息 getItem()可在不同页面通过getItem('msg')获取到 str
        const str = "我是要保存的信息";
        sessionStorage.setItem('msg', str);
        sessionStorage.getItem('msg');
        console.log(" - - - -",sessionStorage.getItem('msg'));  //  - - - - 我是要保存的信息
        sessionStorage.clear();
        console.log(" - 1- - -",sessionStorage.getItem('msg'));  //  - 1- - - null

localStorage:

//      通过setItem()方法保存信息 getItem()可在不同页面通过getItem('msg')获取到 str
        const str = "我是要保存的信息";
        localStorage.setItem('msg', str);
        localStorage.getItem('msg');
        console.log(" - - - -",localStorage.getItem('msg'));  //  - - - - 我是要保存的信息
        localStorage.clear();
        console.log(" - 1- - -",localStorage.getItem('msg'));  //  - 1- - - null

clear() 方法可以清除缓存信息。

LocalStorage存储JSON对象的问题

  • 用localStorage.setItem()正确存储JSON对象方法是:
  • 存储前先用JSON.stringify()方法将json对象转换成字符串形式
  • JSON.stringify() 方法可以将任意的 JavaScript 值序列化成 JSON 字符串
  • 后续要操作该JSON对象,要将之前存储的JSON字符串通过JSON.parse()先转成JSON对象再进行操作

登录用户信息的存储

async function login() {
      //    前台获取登录用户信息
      const result = await userLogin(this.loginForm);
      if (result.code === 1200) {
        //存储user信息到localstorge中,
        const loginUser = result.data.user;
        console.log(" -- - - -",loginUser);
        //        {id: "10051000", lastName: "Francis", firstName: "Zheng", title: "测试用户", functionDep: "Touch-Spring", …}
        console.log(" -- -1 - -",JSON.stringify(loginUser));
        //        {"id":"10051000","lastName":"Francis","firstName":"Zheng","title":"测试用户","functionDep":"Touch-Spring",}
        localStorage.setItem("loginUser", JSON.stringify(loginUser));
        //        路由跳转指定页面
        this.$router.push({path: 'home'});
    }
  }

获取登录用户的信息

   getUserInfo(){
//        通过etItem("loginUser")获取缓存信息
        const data = localStorage.getItem("loginUser");
//        parse() 方法将存储的JSON字符串信息转为JSON对象
        const loginUser = JSON.parse(data);
//        在项目中的任何地方均可的得到缓存的用户信息  
        console.log(" -- -",loginUser.id);
        console.log(" -- -",loginUser.name);
      },

 

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值