vue限制實現不登錄無法進入其他頁面
更新時間:2024年01月05日 09:18:18 作者:小跳不會Coding
本文主要介紹了vue限制實現不登錄無法進入其他頁面,vue限制不登錄,通過url進入其他頁面強制回到登錄頁面;已經登錄的情況下,不可以再進入登錄界面,感興趣的可以了解一下
vue限制不登錄,通過url進入其他頁面強制回到登錄頁面;已經登錄的情況下,不可以再進入登錄界面
參數說明:
- to: Route: 即將要進入的目標(路由對象)
- from: Route: 當前導航正要離開的路由
- next: Function: 一定要調用該方法來 resolve 這個鉤子。執(zhí)行效果依賴 next 方法的調用參數。
1.先在router下的index.js添加 meta:{requireAuth:true},如下:
{ path: '/data', name: 'data', component: data, meta:{requireAuth:true} },
2.然后在main.js添加如下代碼:
router.beforeEach((to, from, next) => { if (to.meta.requireAuth) { // 判斷該路由是否需要登錄權限 if(localStorage.getItem('userInfo')){ //判斷本地是否存在access_token next(); }else { if(to.path === '/login'){ next(); }else { alert('請先進行登錄!') next({ path:'/login' }) } } } else { next(); } /*如果本地 存在 token 則 不允許直接跳轉到 登錄頁面*/ if(to.fullPath == "/login"){ if(localStorage.getItem('userInfo')){ alert('您已經登錄了,如果想要登錄其他賬號,請先退出當前賬號!') next({ path:from.fullPath }); }else { next(); } } });
或者是:
router.beforeEach((to, from, next)=> { let userInfo = localStorage.getItem('userInfo') let list = ['login','checking','register','phoneLogi','chat','GroupSharing','new_file','videoChat',]//多個路由 if (userInfo || list.indexOf(to.name) !== -1) { next() } else { next({ name:'login' }) } // next() })
到此這篇關于vue限制實現不登錄無法進入其他頁面的文章就介紹到這了,更多相關vue限制登錄內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!