同一路由带参刷新,以及params和query两种方式传参的异同
同一路由应该不叫跳转了吧,就先叫刷新好了。
需求及问题
今天做web课设有这样一个需求:
在导航栏中一项叫做教师队伍一级菜单下,有三个二级菜单,分别为教授、副教授、讲师。这三个二级菜单分别对应一个页面。但是由于显示的排版相同,只是教师信息不同,故想用同一页面,通过选择不同的菜单,传入不同的参数,显示不同的信息。
刚开始的想法是,在实例创建阶段,也就是created阶段将导航栏传给子组件的参数获取到
父组件:
    this.$router.push({
        path: '/jsjj',
        query:{
            id:index
        }
    })
子组件:
    created(){
        this.id = this.$route.query.id;
        console.log(this.id);
    },
但是我错了。当第一次跳转复用路由时,created确实可以获取到父组件传递的值,但当带参数刷新当前路由时,created没有被调用。原因是组件已经被创建。
然后尝试了在 Vue 生命周期各个步骤,只有在创建前后,挂载前后可以获取到参数。同样,当路由刷新时又获取不到了。
这可怎么办。后来查阅了度娘,才想起来还有 Vue Router 导航守卫 这么个东西。导航即路由正在发生变化。(哎,还是代码敲得少)
文档中明确说到:
记住参数或查询的改变并不会触发进入/离开的导航守卫。你可以通过观察 $route 对象来应对这些变化,或使用 beforeRouteUpdate 的组件内守卫。
所以要用 beforeRouteUpdate 这个方法来获取当前刷新路由的参数:
    beforeRouteUpdate(to, from, next){
        this.id = to.query.id;
        console.log(this.id);
        next();
    }
其中 next() 方法一定要加,否则路由跳转不会向下执行。
然后又遇到问题,只用 beforeRouteUpdate 方法,当第一次跳转到这个复用路由的时候,又获取不到参数了,原因是只有刷新路由时才会调用这个方法,当第一次进入到路由时不会调用这个方法,所以又获取不到。
那么在第一次跳转进来的时候再获取一下不就好了嘛~把我之前写的 created 方法和 beforeRouteUpdate 方法结合一下,大功告成!
    Create(){
        this.id = this.$route.query.id;
        console.log('a');
        console.log(this.id);
    },
    beforeRouteUpdate(to, from, next){
        this.id = to.query.id;
        console.log('b');
        console.log(this.id);
        next();
        // this.id = this.$route.params.id;
    },
但是这样写总感觉有点难受,毕竟一个是 Vue 的生命周期函数,一个是 Vue Router 的类似钩子函数的函数。
然后发现其实也可以用 Vue Router 的 beforeRouteEnter 函数来实现 Created 里的功能。
解决办法
父组件:
    this.$router.push({
        path: '/jsjj',
        query:{
            id:index
        }
    })
子组件:
    beforeRouteEnter(to, from, next){
        console.log('g');
        console.log(to);
        console.log(to.query.id);
        next();
    },
    beforeRouteUpdate(to, from, next){
        this.id = to.query.id;
        console.log('b');
        console.log(this.id);
        next();
    },
其中还有个问题要注意,一定要使用 query 方式传参,params 方式传餐无效。
强迫症的我得到了解脱!
params 和 query 在路由传值的异同
query 要用 path 来引入,params 要用 name 来引入,接收参数都是类似的,分别是
this.$route.query.name和this.$route.params.name。
this.$router.push({
name:"detail", // 要对应router.js里面的name名称
params:{
name:'nameValue',
code:10011
}
}); // 获取参数
this.$route.params.name this.$router.push({
name:"/detail",
query:{
name:'nameValue',
code:10011
}
}); // 获取参数
this.$route.query.name
- query 更加类似于我们 ajax 中 get 传参,params 则类似于 post,说的再简单一点,前者在浏览器地址栏中显示参数,后者则不显示:
 
query:

params:

总结
- 在路由复用时,分为两个阶段,一个是进入此路由的阶段,也就是 beforeRouteEnter 阶段,另一个是更新路由的阶段,即 beforeRouteUpdate 阶段。
 - 没有区分 Vue 和 Vue Router 的概念,导致在路由上的操作还停留在 Vue 生命周期上。
 - 文档读的不够详细,其实现如今技术上碰到的问题,文档上基本都有写,以后遇事一定要多!看!文!档!!!
 
原文地址:https://segmentfault.com/a/1190000017306664
同一路由带参刷新,以及params和query两种方式传参的异同的更多相关文章
- vue 路由传参 params 与 query两种方式的区别
		
初学vue的时候,不知道如何在方法中跳转界面并传参,百度过后,了解到两种方式,params 与 query.然后,错误就这么来了: router文件下index.js里面,是这么定义路由的: { p ...
 - python flask学习第2天 URL中两种方式传参
		
新创建项目 自己写个url映射到自定义的视图函数 在url中传递参数 app.py from flask import Flask app = Flask(__name__) @app.route ...
 - Node  params和query的Get请求传参
		
//1:加载http express框架//2:创建服务器const http = require("http");const express = require("ex ...
 - C++两种字符串传参构造函数
		
第一种: #include"iostream" #include"string" using namespace std; class Motor{ prote ...
 - Vue路由实现页面跳转的两种方式(router-link和JS)
		
Vue.js 路由可以通过不同的 URL 访问不同的内容,实现多视图的单页 Web 应用 1.通过 <router-link> 实现 <router-link> 组件用于设置一 ...
 - ajax的data传参的两种方式
		
ajax的data传参的两种方式 本文为转载. 1.[javascript] view plain copy /** * 订单取消 * @return {Boolean} 处理是否成功 */ func ...
 - 二十一、springboot之定制URL匹配规则(项目中遇到的问题:get方式传参,带有小数点,被忽略)
		
一.问题描述: get方式传参,在传送价格,积分时(带有小数点),debug后台微服务接受到的参数,却不带小数点,如:price是0.55,后台接受后却是0 二.解决 在WebConfiguratio ...
 - 浅析使用vue-router实现前端路由的两种方式
		
关于vue-router 由于最近的项目中一直在使用vue,所以前端路由方案也是使用的官方路由vue-router,之前在angularJS项目中也是用过UI-router,感觉大同小异,不过很显然v ...
 - vue:子组件通过调用父组件的方法的方式传参
		
在本案例中,由于子组件通过调用父组件的方法的方式传参,从而实现修改父组件data中的对象,所以需要啊使用$forceUpdate()进行强制刷新 父组件: provide() { return { s ...
 
随机推荐
- pip安装源和虚拟环境的搭建
			
一.pip安装源 1.介绍 采用国内源,加速下载模块的速度 常用pip源: 豆瓣:https://pypi.douban.com/simple 阿里:https://mirrors.aliyun.co ...
 - Python字典里的5个黑魔法
			
Python里面有3大数据结构:列表,字典和集合.字典是常用的数据结构,里面有一些重要的技巧用法,我把这些都整理到一起,熟练掌握这些技巧之后,对自己的功力大有帮助. 1.字典的排序: 用万金油sort ...
 - JavaWeb_(SSH论坛)_三、用户模块
			
基于SSH框架的小型论坛项目 一.项目入门 传送门 二.框架整合 传送门 三.用户模块 传送门 四.页面显示 传送门 五.帖子模块 传送门 六.点赞模块 传送门 七.辅助模块 传送门 User表 id ...
 - Alpha发布--美工+文案
			
此作业对应要求参见:https://edu.cnblogs.com/campus/nenu/2019fall/homework/8677 一.美工: 1.产品logo 2.原型页面展示 2.1 进入萌 ...
 - LeetCode 148. 排序链表(Sort List)
			
题目描述 在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序. 示例 1: 输入: 4->2->1->3 输出: 1->2->3->4 示例 ...
 - JSP——隐式对象(implicit object)
			
Servlet容器将几个对象传递给它所运行的Servlet. 例如,在Servlet的service方法中获得HttpServletRequest和HttpServletResponse,并在init ...
 - Dark 面向对象
			
1 继承 使用extends继承一个类 子类会继承父类可见的属性和方法,不包含构造方法 可以复写父类的方法 单继承,多态性 构造方法 子类的构造方法会默认调用父类的无名无参构造方法 如果父类没有无名无 ...
 - leetcode171 Excel列表序列号
			
/** 可看做26进制到10进制转换问题:v=26*v+s[i]-'A'; **/ class Solution { public: int titleToNumber(string s) { ; f ...
 - RTX数据表分析
			
/******************************************* * UserName 做主键 **************************************** ...
 - vsftp新建用户及目录时遇到的坑
			
1.有关vsftp配置及用户权限设置,请参考: http://blog.sina.com.cn/s/blog_3edc5e2e0102vzv8.html 2.需求:公司另一部门要求单独建一目录,来存在 ...