关于vue登录注册,并坚持登录状况,是vue玩家必经之路,网上也有许多的解决要领,但是有一些太过于庞杂,新手能够会看的一脸懵逼,现在给人人引见一种我本身写项目在用而且并不难理解的一种要领。
项目中有一些路由是须要登录才够进入的,比方首页,个人中间等等
有一些路由是不须要登录就能够进入,比方登录页,注册页,遗忘暗码等等
那怎样推断路由是不是须要登录呢?就要在路由JS内里做文章
在router.js中增加meta辨别
比方登录注册页面,不须要登录即可进入,那末我们把meta中的isLogin标志设置为false
{
//登录
path: '/login',
component: login,
meta: {
isLogin: false
}
},
{
//注册
path: '/register',
component: register,
meta: {
isLogin: false
}
},
而在首页我们须要登录才进入,那末我们把meta中的isLogin标志设置为true
{
//首页
path: '/home',
component: home,
meta: {
isLogin: true
},
}
如许我们就为进入各个路由是不是须要登录做了辨别。
接下来我们在login.vue中修正登录后状况
我们运用axios向背景提议登录要求
this.$axios.post("/xxx/login", {user:name,password:pwd})
.then(data => {
//登录失利,先不议论
if (data.data.status != 200) {
//iViewUi的友爱提醒
this.$Message.error(data.data.message);
//登录胜利
} else {
//设置Vuex登录标志为true,默许userLogin为false
this.$store.dispatch("userLogin", true);
//Vuex在用户革新的时刻userLogin会回到默许值false,所以我们须要用到HTML5贮存
//我们设置一个名为Flag,值为isLogin的字段,作用是假如Flag有值且为isLogin的时刻,证实用户已登录了。
localStorage.setItem("Flag", "isLogin");
//iViewUi的友爱提醒
this.$Message.success(data.data.message);
//登录胜利后跳转到指定页面
this.$router.push("/home");
}
});
Vuex内里我是如许写的(假如项目不须要Vuex,那末直接运用HTML5贮存就能够了):
export const store = new Vuex.Store({
// 设置属性
state: {
isLogin: false,
},
// 猎取属性的状况
getters: {
//猎取登录状况
isLogin: state => state.isLogin,
},
// 设置属性状况
mutations: {
//保留登录状况
userStatus(state, flag) {
state.isLogin = flag
},
},
// 运用mutations
actions: {
//猎取登录状况
userLogin({commit}, flag) {
commit("userStatus", flag)
},
}
})
重点来了~,在mian.js里
router.beforeEach((to, from, next) => {
//猎取用户登录胜利后贮存的登录标志
let getFlag = localStorage.getItem("Flag");
//假如登录标志存在且为isLogin,即用户已登录
if(getFlag === "isLogin"){
//设置vuex登录状况为已登录
store.state.isLogin = true
next()
//假如已登录,还想想进入登录注册界面,则定向回首页
if (!to.meta.isLogin) {
//iViewUi友爱提醒
iView.Message.error('请先退出登录')
next({
path: '/home'
})
}
//假如登录标志不存在,即未登录
}else{
//用户想进入须要登录的页面,则定向回登录界面
if(to.meta.isLogin){
next({
path: '/login',
})
//iViewUi友爱提醒
iView.Message.info('请先登录')
//用户进入无需登录的界面,则跳转继承
}else{
next()
}
}
});
router.afterEach(route => {
window.scroll(0, 0);
});
如许就已完成了Vue的登录注册,当用户封闭浏览器或许第二天再次进入网站,用户照旧能够坚持着登录的状况直到用户手动退出登录。
Tips:用户退出只须要localStorage.removeItem(“Flag”)即可