场景:运行项目,登录后跳到首页,新开一个标签页并访问首页,状态是未登录状态 理想结果: 1、无论打开多少个标签页,访问同一个项目,都是同一个登录状态; 2、切换账号后其余标签跟着切换; 3、更换头像后,其他标签页跟着切换; 4、退出登录其余页面跟着退出; 不多说,上代码:
在main.js添加存储的监听
app.config.globalProperties.$addStorageEvent = function (key, data) {
var newStorageEvent = document.createEvent('StorageEvent');
const storage = {
setItem: function (k, val) {
sessionStorage.setItem(k, val)
newStorageEvent.initStorageEvent('setItem', false, false, k, null, val, null, null);
window.dispatchEvent(newStorageEvent);
}
}
storage.setItem(key, data);
if (!data) {
sessionStorage.clear();
localStorage.setItem('sessionStorage', "");
localStorage.removeItem('sessionStorage');
} else {
if (sessionStorage.getItem('userInfo') && JSON.parse(sessionStorage.getItem('userInfo'))) {
localStorage.setItem('sessionStorage', sessionStorage.getItem('userInfo'));
localStorage.removeItem('sessionStorage');
}
}
}
window.addEventListener('storage', function (event) {
if (event.key == 'getSessionStorage') {
if (sessionStorage.getItem('userInfo') && JSON.parse(sessionStorage.getItem('userInfo'))) {
localStorage.setItem('sessionStorage', sessionStorage.getItem('userInfo'));
localStorage.removeItem('sessionStorage');
}
} else if (event.key == 'sessionStorage') {
if (event.newValue && event.newValue != '' && event.newValue != 'null') {
sessionStorage.setItem('userInfo', event.newValue);
var newStorageEvent = document.createEvent('StorageEvent');
newStorageEvent.initStorageEvent('setItem', false, false, '', null, '', null, null);
window.dispatchEvent(newStorageEvent);
}
if(event.newValue == ''){
var newStorageEvents = document.createEvent('StorageEvent');
newStorageEvents.initStorageEvent('setItem', false, false, '', null, '', null, null);
window.dispatchEvent(newStorageEvents);
sessionStorage.clear();
}
}
});
home.vue 登录时将信息写入session
import { Login } from "@http/index.js";
mounted() {
if (
window.location.href.indexOf("ticket") > -1 &&
!this.$utils.getToken()
) {
this.service = window.location.href.slice(
0,
window.location.href.indexOf("ticket") - 1
);
this.ticket = window.location.href.slice(
window.location.href.indexOf("ticket") + 7
);
this.getUserInfo();
}
},
methods: {
getUserInfo() {
Login({ service: this.service, ticket: this.ticket })
.then((res) => {
if (res.code === "0") {
this.$addStorageEvent("userInfo", JSON.stringify(res.result));
localStorage.setItem("getSessionStorage", Date.now());
} else {
this.$ElMessage.error(res.message);
}
})
.catch((err) => {
console.log(err);
});
},
},
head.vue 头部监听session变动(userInfo包含头像地址,head.vue主要就是监听头像的变动)
<el-avatar size="small" :src="userInfo.avatar ? userInfo.avatar : ''" @click="personalDrawer = !personalDrawer" style="margin-left:28px; cursor:pointer;"></el-avatar>
mounted() {
window.addEventListener("setItem", () => {
this.$nextTick(() => {
this.userInfo = this.$utils.getUserInfo();
});
});
},
|