JS前端本地存储信息 localStorage

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Frankenstein_/article/details/86525813

什么是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);
      },

猜你喜欢

转载自blog.csdn.net/Frankenstein_/article/details/86525813