vue-router之退出处理

1、对于vue-router3 (vue2) 官方没有提供删除方法

策略:创建新的router对象,将matcher 赋值给旧的

const router1=new Vue ({...})  

const router2=new Vue ({...})  

router1.matcher = router2.matcher

const createRouter = () => new Router({
  // mode: 'history', // require service support
  scrollBehavior: () => ({ y: 0 }),
  routes: constantRoutes
})

const router = createRouter()

// Detail see: https://github.com/vuejs/vue-router/issues/1234#issuecomment-357941465
export function resetRouter() {
  const newRouter = createRouter()
  router.matcher = newRouter.matcher // reset router
}

2、vuew-router4 (vue3) 提供了

removeRoute 方法删除注册路由,
export function resetRouter(){
    let routers = router.getRoutes()
    routers.map(it=>{
        if(!['login','404','notFind'].includes(it.name)){
            router.removeRoute(it.name)
        }
    })
}

3、整体方案:

删除token,跳转到登录页,同时清除已注册路由(防止切换角色后还能访问另一个角色的权限),beforeEach中加有无token检测

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js 3中,退出登录清空路由可以通过以下步骤实现: 1. 首先,在你的应用程序中创建一个用于管理用户登录状态的状态管理模块(如Vuex)。在该模块中,定义一个用于存储用户登录状态的变量,例如`isLoggedIn`。 2. 当用户点击退出登录按钮时,触发一个方法来更新`isLoggedIn`的值为`false`,表示用户已退出登录。 3. 在你的路由配置文件中,使用导航守卫(Navigation Guards)来检查用户的登录状态。在导航守卫中,判断`isLoggedIn`的值,如果为`false`,则将用户重定向到登录页面或其他需要登录才能访问的页面。 4. 当用户退出登录时,你可以使用Vue Router提供的方法来清空路由历史记录。可以通过调用`router.replace()`方法来将当前路由替换为登录页面的路由,这样用户无法通过浏览器的后退按钮返回到之前的页面。 下面是一个示例代码: ```javascript // 在状态管理模块中定义isLoggedIn变量和更新方法 const state = { isLoggedIn: false }; const mutations = { setLoggedIn(state, value) { state.isLoggedIn = value; } }; // 在路由配置文件中使用导航守卫 router.beforeEach((to, from, next) => { if (to.meta.requiresAuth && !store.state.isLoggedIn) { next('/login'); // 重定向到登录页面 } else { next(); } }); // 在退出登录的方法中更新isLoggedIn的值,并清空路由历史记录 methods: { logout() { this.$store.commit('setLoggedIn', false); this.$router.replace('/login'); } } ``` 这样,当用户退出登录时,会将`isLoggedIn`的值更新为`false`,并且通过`router.replace()`方法将当前路由替换为登录页面的路由,从而清空路由历史记录。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值