先说下传参的几种基本方式

方案一:

getDescribe(id) {

直接调用$router.push 实现携带参数的跳转

this.$router.push({

path: `/describe/${id}`,

})

方案一,需要对应路由配置如下:

{

path: '/describe/:id',

name: 'Describe',

component: Describe

}

很显然,需要在path中添加/:id来对应 $router.push 中path携带的参数。在子组件中可以使用来获取传递的参数值。

this.$route.params.id

方案二:

父组件中:通过路由属性中的name来确定匹配的路由,通过params来传递参数。

this.$router.push({

name: 'Describe',

params: {

id: id

}

})

对应路由配置: 注意这里不能使用:/id来传递参数了,因为父组件中,已经使用params来携带参数了。

{

path: '/describe',

name: 'Describe',

component: Describe

}

子组件中: 这样来获取参数

this.$route.params.id

方案三:

父组件:使用path来匹配路由,然后通过query来传递参数

这种情况下 query传递的参数会显示在url后面?id=?

this.$router.push({

path: '/describe',

query: {

id: id

}

})

对应路由配置:

{

path: '/describe',

name: 'Describe',

component: Describe

}

对应子组件: 这样来获取参数

this.$route.query.id

这里要特别注意 在子组件中 获取参数的时候是this.$route.params 而不是

$router 这很重要~~~

看完这些你会不会有params和query区别的疑问呢?

query更加类似于我们ajax中get传参,params则类似于post,说的再简单一点,前者在浏览器地址栏中显示参数,后者则不显示

params与query.png

路由守卫 —— 路由级别的(全局&路由独享)

router.beforeEach

全局前置守卫

当一个导航触发时,全局前置守卫按照创建顺序调用。守卫是异步解析执行,此时导航在所有守卫 resolve 完之前一直处于 等待中

如何使用:

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

console.log('全局前置守卫:beforeEach -- next需要调用')

next()

})

一般在这个守卫方法中进行全局拦截,比如必须满足某种条件(用户登录等)才能进入路由的情况

参数to和from都是路由对象 Route

next是个Function,有以下几种用法(from api文档)

next(): 进行管道中的下一个钩子。如果全部钩子执行完了,则导航的状态就是 confirmed (确认的)

next(false): 中断当前的导航。如果浏览器的 URL 改变了(可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址 —— 也就是说并不是单纯的中断,还会检查URL的变更以保证不会错误的进入到next路由

next('/') 或者 next({ path: '/' }): 跳转到一个不同的地址。当前的导航被中断,然后进行一个新的导航。可传递的参数与router.push中选项一致

next(error): (v2.4.0+) 如果传入 next 的参数是一个 Error 实例,则导航会被终止且该错误会被传递给 router.onError() 注册过的回调

router.beforeResolve (v 2.5.0+)

全局解析守卫

和beforeEach类似,区别是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就被调用

即在 beforeEach 和 组件内beforeRouteEnter 之后

参数和beforeEach一致,也需要调用next对导航确认

router.afterEach

全局后置钩子

在所有路由跳转结束的时候调用

这些钩子不会接受 next 函数也不会改变导航本身

beforeEnter

可直接定义在路由配置上,和beforeEach方法参数、用法相同

路由守卫 —— 组件内

beforeRouteEnter

在渲染该组件的对应路由被确认前调用,用法和参数与beforeEach类似,next需要被主动调用

注意:

此时组件实例还未被创建,不能访问this

可以通过传一个回调给 next来访问组件实例。在导航被确认的时候执行回调,并且把组件实例作为回调方法的参数

beforeRouteEnter (to, from, next) {

// 这里还无法访问到组件实例,this === undefined

next( vm => {

// 通过 `vm` 访问组件实例

})

}

可以在这个守卫中请求服务端获取数据,当成功获取并能进入路由时,调用next并在回调中通过 vm访问组件实例进行赋值等操作

beforeRouteEnter触发在导航确认、组件实例创建之前:beforeCreate之前;而next中函数的调用在mounted之后:为了确保能对组件实例的完整访问

beforeRouteUpdate (v 2.2+)

在当前路由改变,并且该组件被复用时调用,可以通过this访问实例, next需要被主动调用,不能传回调

对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,组件实例会被复用,该守卫会被调用

当前路由query变更时,该守卫会被调用

vue-router推荐的数据获取方法二中,结合beforeRouteEnter使用,在路由参数变更时可以重新获取数据,获取成功再调用next(),参考:https://router.vuejs.org/zh-c...

之前在手机浏览器中好像发现这个守卫的bug?@TODO 待确认

beforeRouteLeave

导航离开该组件的对应路由时调用,可以访问组件实例 this,next需要被主动调用,不能传回调

路由守卫 AJAX,vue路由传参与路由守卫相关推荐

  1. 路由守卫 AJAX,vue路由导航守卫 和 请求拦截以及基于node的token认证

    #####什么时候需要登录验证与权限控制 1.业务系统通常需要登录才能访问受限资源,在用户未登录情况下访问受限资源需要重定向到登录页面: 2.多个业务系统之间要实现单点登录,即在一个系统或应用已登录的 ...

  2. vue2路由手动创建二级路由路由传参路由守卫打包上线

    路由手动配置: #在@vue/cli创建的项目中,路由用法如下. 1.安装路由npm install vue-router@32:定义路由所需的组件(.vue文件)要实现页面about 和home两个 ...

  3. vue 声明周期函数_vue-router路由守卫-上

    1. 为什么要使用路由守卫?什么是路由守卫? 第一次认识路由守卫:之前我做过的小项目里面,我们直接在浏览器网址的地方进行修改就能跳转页面,这是不安全的,因此就需要路由守卫,实现通过路由拦截,来判断用户 ...

  4. vue的三种路由守卫

    路由守卫就是当⻚⾯跳转的时候会触发的钩⼦函数, vue⼀共给我们提供了三种路由守卫 全局路由守卫 前置守卫: router.beforeEach((to,from,next) => {}) to ...

  5. vue 401问题和路由守卫

    前言: 日常使用淘宝时,如果我没登录,是不能购买的,会提示我先登录,于是我输入账号密码,跳转到我刚才的页面.而我只要登陆了,下次使用淘宝也不需再重复输入账号密码.直到我还久没登陆了,才需要我重新登录. ...

  6. 尚硅谷VUE项目-前端项目问题总结07--产品详情页【vuex-排他操作foreach-放大镜-轮播图-兄弟组件通信$bus-购物车-路由跳转传参-路由传参+会话存储】-游客身份-节流

    尚硅谷VUE项目-前端项目问题总结07---产品详情页 1.静态组件(详情页还未注册为路由组件) 2.发请求 3.vuex-获取产品详情信息 3.1放大镜 3.2 属性值[排他操作] 3.3轮播图[j ...

  7. Vue Router:vue中实现前端路由

    Vue Router 官方文档 文章目录 一.路由简介 路由分类 路由安装 二.路由基本使用 安装路由器并设置路由规则 实现路由切换 指定组件的呈现位置 this中的 $router 和 $route ...

  8. vue学习之VueRouter 路由

    文章目录 vue router 1.认识路由的概念 1.1.何为路由 1.2.后端路由阶段 1.3.前端路由阶段 1.4.前端渲染和后端渲染? 2.前端路由的规则 2.1.URL的hash 方式 2. ...

  9. vue 定义全局弹框_VUE路由拦截:Vue自定义全局弹窗组件

    前言 在任何一个平台中,如果需要增加用户黏度,除了用户需要的基本内容外,用户登录注册提交信息也是非常重要的一环,可以了解用户基本信息,用户喜欢等. 抛出前后端混合开发外,vue可以轻松的实现路由拦截. ...

  10. 【Vue知识点- No7.】路由、vant组件库的使用

    No7.路由.vant组件库的使用 学习目标 1.能够了解单页面应用概念和优缺点 2.能够掌握vue-router路由系统使用 3.能够掌握链接导航和编程式导航用法 4.能够掌握路由嵌套和路由守卫 5 ...

最新文章

  1. java 类定义_JAVA类与对象(二)----类定义基础
  2. 调用API弹出打印机属性对话框
  3. 魔力宝贝服务器列表修改,魔力宝贝修改代码一览表GM.docx
  4. 北美公司面试经验笔记
  5. [经典推荐]事半功倍系列之javascript
  6. linux mint php mysql_linux mint 下mysql中文支持问题
  7. C#LeetCode刷题之#31-下一个排列(Next Permutation)
  8. Nginx+keepalive反向代理
  9. 再谈UDP协议—浅入理解深度记忆
  10. php获取用户 地区 、ip地址
  11. Python 核心编程 (全)
  12. CMS垃圾回收器总结
  13. 分享:绘图不可不知的CAD经典技巧
  14. 如何通过Python发送邮件实现自动化测试报告?
  15. 《重说中国近代史》—张鸣—(3)两个世界最初的碰撞(续)
  16. java程序设计--孙鑫java无难事Lesson3《包、类和方法说明符、垃圾回收、接口》
  17. 计算机处理io和cpu,虚拟化技术原理(CPU、内存、IO)
  18. 7-45 水果忍者 (30 point(s))
  19. 数值积分之龙贝格积分
  20. Windows下如何快速查看并导出系统详细信息(计算机名、操作系统、系统制造商、系统型号、BIOS、CPU及内存大小)

热门文章

  1. 【方法篇】S-棕榈酰化蛋白修饰质谱鉴定方法
  2. 落户雄安,千方科技助力新区打造智慧出行样板
  3. 老视频修复完整教程:Topaz Video Enhance AI 提升分辨率+RIFE算法补帧
  4. excellvba引用计算机用户名,EXCEL VBA 取当前登录 用户名的多种实现方法
  5. 关于大内存(大于4G)支持的问题
  6. 番薯借阅--图书管理系统(小程序)
  7. php 生成圆形 图片,php 图片处理 - 将图片变成圆形
  8. 对比苏州和杭州这两座城市,你会发现?
  9. 机器学习入门09 - 特征组合 (Feature Crosses)
  10. linux编辑文件发生错误E45: ‘readonly‘ option is set (add ! to override)