我遇到了 Vue.js 的新问题,我正在使用我的登录页面登录我的应用程序,一切正常,如果它是管理员配置文件,它会转到管理页面,普通用户会转到主页。
但是如果我是管理员并且我用 F5 硬刷新页面然后我不能再去管理页面。我想我知道我的插件调用顺序有问题,我需要在路由器之前调用我的 localStorage,但我没有为 localStorage 使用插件。
这是代码,首先是路由器的 beforeEach 函数:
router.beforeEach(async (to, from, next) => {
let user = await store.getters.userInSession;
let token = await store.getters.getToken;
if(to.matched.some(record => record.meta.requiresAuth) && token == '') {
next({ name : 'Connexion'})
} else if (to.matched.some(record => record.meta.is_admin) && user.role != "Admin"){
next({ name: 'Tableau de bord'})
} else if(to.matched.some(record => record.meta.guest) && token != '') {
next({ name: 'Tableau de bord'})
} else {
next();
}
})
然后这是我从 vuex 访问我的 localStorage 的方式:
import Vue from 'vue';
import router from '../../router';
const state = {
token: localStorage.getItem('token'),
user: localStorage.getItem('user'),
errors: []
};
const getters = {
isAuthenticated: state => !!state.token,
userInSession: state => {
return state.user;
},
isAdmin: state => {
return state.user ? state.user.role == 'Admin' : false
},
getToken: state => {
return state.token ? state.token : "";
}
};
我尝试使用 vue-localstorage 并将其放在路由器之前的 Vue 实例中,但我什至不知道如何全局设置它。它没有被识别为 pluginObject,所以我不能用这个来做 Vue.use。
无论如何我试过这个:
import Vue from 'vue';
import App from './App.vue';
import router from './router';
import store from './store';
import VueLocalStorage from 'vue-localstorage';
import vuetify from './plugins/vuetify';
new Vue({
VueLocalStorage,
router,
store,
vuetify,
render: h => h(App)
}).$mount('#app')
我认为最后一件事是相关的,但我不确定,我在 my 中显示了我的用户信息,并且在一次硬刷新之后它也消失了......我这样称呼它:
它与我从 vuex 访问的对象相同。如果有人有线索,将不胜感激。
喵喔喔
相关分类