vue组件级路由钩子函数

vue组件级路由钩子函数(beforeRouteEnter/beforeRouteUpdate/beforeRouteLeave)

 

beforeRouteEnter(to, from, next):进入路由之前执行的函数,写在组件里可根据路由进行页面判断或传值。

beforeRouteLeave(to, from, next):离开路由之前执行的函数,可用于页面的反向传值,页面跳转。

 // 点击后拿到数据返回给下单地址
  beforeRouteLeave (to, from, next) {
    if (to.name === 'home') {
      to.query.temp = '这里是参数,选中后的地址'
    }
    console.log(to)
    console.log(from)
    next()//一定不要忘记写
  },

--------------------------------------------------------------------------------------------------------------------------------------------------------------------

beforeRouteEnter(to,from,next)

        beforeRouteEnter 函数内部 this 是undefined,这是因为在执行路由钩子函数beforRouteEnter时候,组件还没有被创建出来;先执行beforRouteEnter,再执行组件周期钩子函数beforeCreate。我们可以通过 next 获取组件的实例对象,如:next( (vm)=>{} ),参数vm就是组件的实例化对象。

<template>
    <div>
        我是about
        <hr>
        <ul class="subnave f-cb">
            <router-link :to='{name:"About"}' exact tag="li">
                <a>study</a>
            </router-link>
            <router-link :to='{name:"Work"}' tag="li">
                <a>work</a>
            </router-link>
            <router-link :to='{name:"Hobby"}' tag="li">
                <a>hobby</a>
            </router-link>
        </ul>
        测试数据:{{test}}
        <router-view></router-view>
    </div>
</template>

<script>
    export default {
        data(){
            return {
                test:'改变之前'
            }
        },
        beforeCreate(){//组件生命周期函数
            console.log('beforeCreate')
        },
        //当进入组件之前,执行 beforRouteEnter 路由钩子函数
        beforeRouteEnter(to,from,next){
            console.log('beforRouteEnter')
            console.log(this) // 结果为undefined,因为在执行beforRouteEnter时候,组件还没有被创建出来;先执行beforRouteEnter,再执行beforeCreate
            next((vm)=>{ //参数vm就是当前组件的实例。
                vm.test = '我被改变了'
            })
        }
    }
</script>

beforeRouteUpdate(to,from,next)

About组件是有二级导航的,在切换二级导航的时候,对应的内容是在变化的;但是about组件是复用的,只会生成一次,切换二级导航的时,如何知道导航在更新呢?

 一个组件有二级导航的时候,点击二级导航的时候导航路径更新了,会触发路由钩子函数beforeRouteUpdate。

beforeRouteUpdate(to,from,next){
    console.log('beforeRouteUpdate')
    next()
}

beforeRouteLeave(to,from,next)

当在about切换到user时,about页面有些数据还没有加载完成,这时候我们不让它切换到user。

beforeRouteLeave(to,from,next){//离开组件的时候触发
    //什么都不写的时候,不会离开(走下一步)
    next()
}

完整demo代码

<template>
    <div>
        我是about
        <hr>
        <ul class="subnave f-cb">
            <!-- a标签中href属性不需要写地址,页面编译完成后自动会在href中加入对应的路劲 -->
            <router-link :to='{name:"About"}' exact tag="li">
                <a>study</a>
            </router-link>
            <router-link :to='{name:"Work"}' tag="li">
                <a>work</a>
            </router-link>
            <router-link :to='{name:"Hobby"}' tag="li">
                <a>hobby</a>
            </router-link>
        </ul>
        测试数据:{{test}}
        <router-view></router-view>
    </div>
</template>

<script>
    export default {
        data(){
            return {
                test:'改变之前'
            }
        },
        beforeCreate(){//组件生命周期函数
            console.log('beforeCreate')
        },
        //当进入组件之前,执行 beforRouteEnter 路由钩子函数
        beforeRouteEnter(to,from,next){
            console.log('beforRouteEnter')
            console.log(this) // 结果为undefined,因为在执行beforRouteEnter时候,组件还没有被创建出来;先执行beforRouteEnter,再执行beforeCreate
            next((vm)=>{ //参数vm就是当前组件的实例。
                vm.test = '我被改变了'
            })
        },
        beforeRouteUpdate(to,from,next){
            console.log('beforeRouteUpdate')
            next()
        },
        beforeRouteLeave(to,from,next){//离开组件的时候触发
            //什么都不写的时候,不会离开(走下一步)
            next()
        }
    }
</script>

 

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3中,组件路由钩子函数有两种方式可以使用。 第一种是使用全局钩子函数,包括beforeEach、afterEach和beforeResolve。这些钩子函数可以在router对象的创建过程中进行定义,例如在router/index.js文件中: ```javascript import { createRouter } from 'vue-router' const router = createRouter({ routes: \[...\], }) router.beforeEach((to, from, next) => { // 在路由跳转之前进行一些校验、权限判断等操作 next() }) router.afterEach((to, from) => { // 在路由跳转之后进行一些操作,如记录用户的浏览记录等 }) router.beforeResolve((to, from, next) => { // 全局解析钩子 next() }) export default router ``` 第二种是使用路由独享的守卫函数,可以在单个路由配置中定义beforeEnter钩子函数。例如: ```javascript import { createRouter } from 'vue-router' const router = createRouter({ routes: \[ { path: '/', name: 'Home', component: import('./views/Home.vue'), beforeEnter: (to, from, next) => { // 在路由进入之前进行一些校验操作 next() } }, { path: '/about', name: 'About', component: import('./views/About.vue') } \] }) export default router ``` 在这个例子中,Home组件路由独享钩子函数beforeEnter会在进入该路由之前进行一些校验操作。 总结起来,Vue 3中的组件路由钩子函数可以通过全局钩子函数路由独享钩子函数两种方式来定义和使用。 #### 引用[.reference_title] - *1* [VUE导航守卫](https://blog.csdn.net/rraxx/article/details/119139615)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Vue3 路由钩子的使用](https://blog.csdn.net/qq_45438471/article/details/130340064)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值