• Vue 路由钩子函数


    在路由跳转的时候,我们需要一些权限判断或者其他操作。这个时候就需要使用路由的钩子函数。
    
    定义:路由钩子主要是给使用者在路由发生变化时进行一些特殊的处理而定义的函数。
    
    总体来讲vue里面提供了三大类钩子,两种函数 1、全局钩子 2、某个路由的钩子 3、组件内钩子
    
    两种函数:
    
    1. router.beforeEach(function(to,form,next){}) /*在跳转之前执行*/
    
    2. router.afterEach(function(to,form)}{}) /*在跳转之后判断*/
    
    全局钩子函数
    
    顾名思义,它是对全局有效的一个函数
    
    JavaScript
    // router.jsconst router = new Router({
     routes: [
      {
       path: '/',
       name: 'sideBar',
       component: sideBar,
       children:[
        {
         path:'/',
         name:'sort',
         component:sort
        },
        {
         path:'/addNewSort',
         name:'addNewSort',
         component:addNewSort
        },
        {
         path:'/notSend',
         name:'notSend',
         component:notSend
        },
        {
         path:'/sended',
         name:'sended',
         component:sended
        },
      }
     ]
    })
    
    router.beforeEach((to,from,next)=>{
     // console.log("to:",to);   // router即将进入的路由对象
     // console.log("from:",from); // 当前导航即将离开的路由
     // console.log("next:",next); // Function,进行管道中的一个钩子,如果执行完了,则导航的状态就是 confirmed (确认的);否则为false,终止导航。
     if(to.name=='notSend'){
      next({
       name:'sort'
      })
      return
     }
     next()
    })
    
    export default router
    某个路由的钩子函数
    
    顾名思义,它是写在某个路由里头的函数,本质上跟组件内函数没有区别。
    
    JavaScript
    // router.jsconst router = new VueRouter({
     routes: [
      {
       path: '/login',
       component: Login,
       beforeEnter: (to, from, next) => {
        // ...
       },
       beforeLeave: (to, from, next) => {
        // ...
       }
      }
     ]
    })
    路由组件的钩子
    
    可以在路由组件内直接定义以下路由导航钩子
    
    JavaScript
    // *.vuebeforeRouteEnter
    beforeRouteUpdate (2.2 新增)
    beforeRouteLeave
    这里简单说下钩子函数的用法:它是和data,methods平级的。
    
    beforeRouteLeave(to, from, next) {
      next()
    },
    beforeRouteEnter(to, from, next) {
      next()
    },
    beforeRouteUpdate(to, from, next) { // 用于相同路由组件的的参数更新
      next()
    },
    data:{},
    method: {}
    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持聚米学院。
    徐增友
  • 相关阅读:
    Java web 例4-7
    JavaScript初步+基本函数
    请求转发和重定向区别
    javaben的设计规则
    Java web 实验五 Servlet过滤器
    关于软件生命周期以及软件过程
    Java web outTime.jsp
    Java web 4-6 update_stu_1.jps
    include指令与动作,请求妆发等同于forward动作
    简单的购物车应用案例 相关代码2
  • 原文地址:https://www.cnblogs.com/xzybk/p/14532289.html
Copyright © 2020-2023  润新知