localstorage可以说是对cookie的优化,使用它可以方便在客户端存储数据,并且不会随着HTTP传输
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对象的问题
JSON.stringify()
方法可以将任意的 JavaScript 值序列化成 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);
},