Vue-router编程式导航及路由导航守卫

1.route 和 router的区别

this.$route  是路由的 “参数对象”
this.$router 是路由的 “导航对象”

路径参数和查询参数

在路由“参数对象”中,需要使用 this.$route.params 来访问路径参数
使用 this.$route.query 来访问查询参数
	<!-- 注意1:在 hash 地址中, / 后面的参数项,叫做“路径参数” -->
    <!-- 在路由“参数对象”中,需要使用 this.$route.params 来访问路径参数 -->

    <!-- 注意2:在 hash 地址中,? 后面的参数项,叫做“查询参数” -->
    <!-- 在路由“参数对象”中,需要使用 this.$route.query 来访问查询参数 -->

    <!-- 注意3:在 this.$route 中,path 只是路径部分;fullPath 是完整的地址 -->
    <!-- 例如: -->
    <!-- /movie/2?name=zs&age=20 是 fullPath 的值 -->
    <!-- /movie/2 是 path 的值 -->
    <router-link to="/movie/1">洛基</router-link>
    <router-link to="/movie/2?name=zs&age=20">雷神</router-link>
    <router-link to="/movie/3">复联</router-link>

2.编程式导航

2.1声明式导航 & 编程式导航

在这里插入图片描述

2.2vue-router 中的编程式导航 API

vue-router 提供了许多编程式导航的 API,其中最常用的导航 API 分别是:

① this.$router.push('hash 地址'): 跳转到指定 hash 地址,并增加一条历史记录
② this.$router.replace('hash 地址'): 跳转到指定的 hash 地址,并替换掉当前的历史记录
③ this.$router.go(数值 n): 实现导航历史前进、后退

push 和 replace 的区别:

push 会增加一条历史记录
replace 不会增加历史记录,而是替换掉当前的历史记录

$router.go 的简化用法:

① $router.back() 在历史记录中,后退到上一个页面
② $router.forward() 在历史记录中,前进到下一个页面

3.params和query传参的区别

用params传参,F5强制刷新参数会被清空,参数不会显示到路径上。路由配置时要在path属性值得后面加‘/?*’ 例如:/:id

用query,由于参数适用路径传参的所以F5强制刷新也不会被清空,参数会显示到路径

3.1 params传参刷新数据会消失怎么解决:
1.在 created 生命周期时,localstroage 先缓存数据,在页面销毁时删除缓存

created() {
    let rowData = localStorage.getItem('rowData')
    if(rowData) {
      this.row = this.$route.params.row
      localStorage.setItem('rowData', JSON.stringify(this.$route.params.row))
    }
  },
  beforeDestory() {
    localStorage.removeItem('rowData')
  }

2使用 Vuex 仓库存储数据

4.路由导航守卫

导航守卫可以控制路由的访问权限。示意图如下:
在这里插入图片描述

4.1 全局前置守卫及三个参数

为 router 实例对象,声明全局前置导航守卫
只要发生了路由的跳转,必然会触发 beforeEach 指定的 function 回调函数

控制后台主页的访问权限

router.beforeEach(function(to, from, next) {
// to 表示将要访问的路由的信息对象
  // from 表示将要离开的路由的信息对象
  // next() 函数表示放行的意思
  // 分析:
  // 1. 要拿到用户将要访问的 hash 地址
  // 2. 判断 hash 地址是否等于 /main。
  // 2.1 如果等于 /main,证明需要登录之后,才能访问成功
  // 2.2 如果不等于 /main,则不需要登录,直接放行  next()
  // 3. 如果访问的地址是 /main。则需要读取 localStorage 中的 token 值
  // 3.1 如果有 token,则放行
  // 3.2 如果没有 token,则强制跳转到 /login 登录页
  if (to.path === '/main') {
    // 要访问后台主页,需要判断是否有 token
    const token = localStorage.getItem('token')
    if (token) {
      next()
    } else {
      // 没有登录,强制跳转到登录页
      next('/login')
    }
  } else {
    next()
  }
})
4.2 next 函数的 3 种调用方式

当前用户拥有后台主页的访问权限,直接放行:next()
当前用户没有后台主页的访问权限,强制其跳转到登录页面:next(’/login’)
当前用户没有后台主页的访问权限,不允许跳转到后台主页:next(false)

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值