纵横研究院VU...

vue 路由

2020-07-12  本文已影响0人  BlinglingSam

动态路由

使用动态路由配置的(如:‘:id’),可以在this.$router.params.id获得。

官网例子:

模式 匹配路径 $route.params
/user/:username /user/evan { username: 'evan' }
/user/:username/post/:post_id /user/evan/post/123 { username: 'evan', post_id: 123 }

⚠️注意:当使用路由参数时,例如从 /user/foo 导航到 /user/bar,原来的组件实例会被复用。因为两个路由都渲染同个组件,比起销毁再创建,复用则显得更加高效。
不过,这也意味着组件的生命周期钩子不会再被调用。此时可以使用:watch监听$route对象,或者导航守卫beforeRouterUpdate

router和route的区别

前者是全局路由对象,后者是当前路由。

嵌套路由

要注意,以 / 开头的嵌套路径会被当作根路径。 使我们充分的使用嵌套组件而无须设置嵌套的路径。

编程式路由

路由传参数:如果提供了 pathparams 会被忽略

命名视图

同个路由多个视图:如果 router-view 没有设置名字,那么默认为 default

  <router-view class="view one"></router-view>
  <router-view class="view two" name="a"></router-view>
  <router-view class="view three" name="b"></router-view>

导航守卫

  router.beforeResolve   在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后11,
const router = new VueRouter({
  routes: [
    {
      path: '/foo',
      component: Foo,
      beforeEnter: (to, from, next) => {
        // ...
      }
    }
  ]
})12,beforeRouteEnter 守卫 不能 访问 this,update,leave可以访问this。仅仅是beforeRouterEnter支持next传递回调。

``beforeRouteEnter守卫 不能 访问this,因为守卫在导航确认前被调用,因此即将登场的新组件还没被创建。不过,你可以通过传一个回调给next来访问组件实例。在导航被确认的时候执行回调,并且把组件实例作为回调方法的参数。

beforeRouteEnter (to, from, next) { next(vm => { // 通过vm访问组件实例 }) }

vue-router 配合axios拦截器的操作

//http request拦截器
authedAxios.interceptors.request.use((request) => {
  let res = checkSession()
  console.log('未获取到token,先获取token')
  let token = storage.get('userToken')
  // request.headers['userId'] = token.userId
  request.headers['Authorization'] = `Bearer ${token}`
  return request
}, (err) => {
  // 请求发生错误
  if (err) {
    console.log(err)
    toast.show(err.message)
    return Promise.reject(err)
  }
})

// //http response拦截器
authedAxios.interceptors.response.use((response) => {
  let result = response.data
  if (result.success) {
    return Promise.resolve(result)
  }
  const message = result.message
  toast.show(`操作失败!${message}`)
  return Promise.reject(result)
},(responseError) => {
  if (responseError) {
    switch (error.response.status) {
      case 401:
      // 返回 401 清除token信息并跳转到登录页面
          store.commit(types.LOGOUT);
          router.replace({path: 'login',query: {redirect: router.currentRoute.fullPath}
   })
    }
  }
return Promise.reject(error.response.data) // 返回接口返回的错误信息
})

完整的导航解析流程

  1. 导航被触发。
  2. 在失活的组件里调用离开守卫。
  3. 调用全局的 beforeEach 守卫。
  4. 在重用的组件里调用 beforeRouteUpdate 守卫 (2.2+)。
  5. 在路由配置里调用 beforeEnter
  6. 解析异步路由组件。
  7. 在被激活的组件里调用 beforeRouteEnter
  8. 调用全局的 beforeResolve 守卫 (2.5+)。
  9. 导航被确认。
  10. 调用全局的 afterEach 钩子。
  11. 触发 DOM 更新。
  12. 用创建好的实例调用 beforeRouteEnter 守卫中传给 next 的回调函数。
上一篇下一篇

猜你喜欢

热点阅读