美文网首页
Vue路由守卫

Vue路由守卫

作者: itfitness | 来源:发表于2022-06-23 10:41 被阅读0次

全局守卫

全局守卫我们用beforeEach函数

const router =  new VueRouter({
    routes:[
        {
            name:"Home",
            path:"/Home",
            component:Home,
            props:true,
            children:[
                {
                    path:"Circle",
                    component:Circle
                },
                {
                    path:"Foucs",
                    component:Foucs
                }
            ]
        },
        {
            path:"/About",
            component:About
        }
    ]
})

router.beforeEach((to,from,next)=>{
    console.log(to)
})

代码中我们输出to、from和next,然后我们点击首页查看输出,发现to为要跳转的路由,from是当前的路由,next是跳转的函数



接下来我们可以通过给路由配置的meta参数来控制是否可以跳转

const router =  new VueRouter({
    routes:[
        {
            name:"Home",
            path:"/Home",
            component:Home,
            props:true,
            meta:{
                canJump:true
            },
            children:[
                {
                    path:"Circle",
                    component:Circle
                },

                {
                    path:"Foucs",
                    component:Foucs
                }
            ]
        },
        {
            path:"/About",
            component:About,
            meta:{
                canJump:false
            }
        }
    ]
})

router.beforeEach((to,from,next)=>{
    if(to.meta.canJump){
        next()
    }else{
        alert("不可跳转")
    }
})

独享守卫

就是在配置路由的时候给路由加入beforeEnter函数

const router =  new VueRouter({
    routes:[
        {
            name:"Home",
            path:"/Home",
            component:Home,
            props:true,
            meta:{
                canJump:true
            },
            children:[
                {
                    path:"Circle",
                    component:Circle
                },
                {
                    path:"Foucs",
                    component:Foucs
                }
            ]
        },
        {
            path:"/About",
            component:About,
            //独享守卫
            beforeEnter(to,from,next){
                alert("不可跳转")
            },
            meta:{
                canJump:false
            }
        }
    ]
})

组件守卫

组件内可以通过beforeRouteEnter和beforeRouteLeave来监控路由的跳转进来和跳转出去

<script>
    export default {
        data(){
            return {
                num:0
            }
        },
        methods: {
            add() {
                this.num++
            }
        },
        beforeRouteEnter(to,from,next){
            console.log("进入")
            next()
        },
        beforeRouteLeave(to,from,next){
            console.log("离开")
            next()
        }
    }
</script>

相关文章

  • 华云

    一,vue路由守卫的生命周期1,全局的前置路由守卫 router.beforeEach()2, 全局解析守卫 ...

  • react实现路由守卫

    与vue不同,vue直接使用beforeEach即可实现全局路由守卫等功能。react要实现路由守卫得自己配置。实...

  • vue-router 常见导航守卫

    全局守卫vue-router全局有三个守卫 路由独享守卫如果你不想全局配置守卫的话,你可以为某些路由单独配置守卫 ...

  • vue 路由导航白话全解析

    这里先放上官网的教程和说明:点击这里,vue导航守卫官方文档 路由守卫 路由守卫说白了就是路由拦截,在地址栏跳转之...

  • Vue导航守卫

    Vue导航守卫 理解 导航守卫也叫路由守卫,可以实时的监控路由的跳转过程,在路由的跳转的各个过程执行相应的操作,有...

  • Vue-Router 导航守卫

    导航守卫 导航表示路由正在发生改变。(变化的路由)导航守卫就是变化的路由钩子。路由钩子的意思可以理解为vue-ro...

  • 关于vue路由守卫做登陆状态判断的问题

    关于vue路由守卫做登陆状态判断的问题 直接上代码 // 全局路由守卫 router.beforeEach((to...

  • Vue路由/路由守卫

    一、前端路由和后端路由概念解释 二、路由的基本使用方式 三、常见引入路由组件的方式和区别 四、常见引入路由分类1....

  • Vue - 路由守卫(路由的生命周期)

    路由守卫是什么? 官方解释:“导航”表示路由正在发生改变。正如其名,vue-router提供的导航守卫主要用来通过...

  • vue-router进阶

    导航守卫 vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航(路由发生改变才会守卫)。参数 ...

网友评论

      本文标题:Vue路由守卫

      本文链接:https://www.haomeiwen.com/subject/kwbpvrtx.html