Vue路由传参的几种方式
Vue路由传参的几种方式
前言:顾名思义,vue路由传参是指嵌套路由时父路由向子路由传递参数,否则操作无效。传参方式可以划分为params传参和query传参,params传参又可以分为url中显示参数和不显示参数两种方式。具体区分和使用后续分析。
参考官网:https://router.vuejs.org/zh/guide/essentials/navigation.html
params传参(url中显示参数)
- 文件结构
- 定义路由:在定义path路由路径时定义参数名和格式,如 path: "/one/login/:num" ,router>index.js文件如下
- /* eslint-disable*/
- //第一步:引用vue和vue-router ,Vue.use(VueRouter)
- import Vue from 'vue'
- import Router from 'vue-router'
- Vue.use(Router)
- //第二步:引用定义好的路由组件
- import ChildOne from '../components/childOne'
- import ChildTwo from '../components/childTwo'
- import Log from '../components/log.vue'
- import Reg from '../components/reg.vue'
- //第三步:定义路由(路由对象包含路由名、路径、组件、参数、子路由等),每一个路由映射到一个组件
- //第四步:通过new Router来创建router实例
- export default new Router({
- mode: 'history',
- routes: [
- {
- path: '/one',
- name: 'ChildOne',
- component: ChildOne,
- children:[
- {
- path:'/one/log/:num',
- component:Log,
- },
- {
- path:'/one/reg/:num',
- component:Reg,
- },
- ],
- },
- {
- path: '/two',
- name: 'ChildTwo',
- component: ChildTwo
- }
- ]
- })
- 在父路由组件上使用router-link进行路由导航,传参用<router-link to="/one/login/001">的形式向子路由组件传递参数。使用router-view进行子路由页面内容渲染,父路由组件childOne.vue 如下:
- <template>
- <div style="border:1px solid red;color:red;">
- <p>这是父路由childOne对应的组件页面</p>
- <p>下面可以点击显示嵌套的子路由 </p>
- <router-link to="/one/log/123">显示登录页面</router-link>
- <router-link to="/one/reg/002">显示注册页面</router-link>
- <router-view></router-view>
- </div>
- </template>
- 子路由通过 this.$route.params.num 的形式来获取父路由向子路由传递过来的参数,子路由组件login.vue如下:
- <template>
- <div style="border:1px solid orange;color:orange;">
- <p>登录界面:这是另一个嵌套路由的内容</p>
- <h3>{{this.$route.params.num}}</h3>
- </div>
- </template>
效果:
注意:如上所述路由定义的path: "/one/login/:num"路径和to="/one/login/001"必须书写正确,否则不断点击切换路由,会因为不断将传递的值显示添加到url中导致路由出错,如下
传递的值存在url中存在安全风险,为防止用户修改,另一种方式不在url中显示传递的值
params传参(url中不显示参数)
- 定义路由时添加name属性给映射的路径取一个别名,router>index.js文件修改router如下:
- export default new Router({
- mode: 'history',
- routes: [
- {
- path: '/one',
- name: 'ChildOne',
- component: ChildOne,
- children:[
- {
- path:'/one/log/',
- name:'Log',
- component:Log,
- },
- {
- path:'/one/reg/',
- name:'Reg',
- component:Reg,
- },
- ],
- },
- {
- path: '/two',
- name: 'ChildTwo',
- component: ChildTwo
- }
- ]
- })
- 在父路由组件上使用router-link进行路由导航,使用 <router-link :to="{name:'home',params:{id:001}}> 形式传递参数。注意 ': to= ' 前面的冒号,childOne.vue组件修改如下:
- <template>
- <div style="border:1px solid red;color:red;">
- <p>这是父路由childOne对应的组件页面</p>
- <p>下面可以点击显示嵌套的子路由 </p>
- <router-link :to="{name:'Log',params:{num:666}}">显示登录页面</router-link>
- <router-link :to="{name:'Reg',params:{num:888}}">显示注册页面</router-link>
- <router-view></router-view>
- </div>
- </template>
- 子路由组件页面获取父路由传参方式不变,reg.vue 文件如下:
- <template>
- <div style="border:1px solid orange;color:orange;">
- <p>登录界面:这是另一个嵌套路由的内容</p>
- <h3>子路由获取的参数:{{this.$route.params.num}}</h3>
- </div>
- </template>
注意:上述这种利用params不显示url传参的方式会导致在刷新页面的时候,传递的值会丢失;
使用Query实现路由传参
- 定义路由 router>index.js文件如下:
- export default new Router({
- mode: 'history',
- routes: [
- {
- path: '/one',
- name: 'ChildOne',
- component: ChildOne,
- children:[
- {
- path:'/one/log/',
- component:Log,
- },
- {
- path:'/one/reg/',
- component:Reg,
- },
- ],
- },
- {
- path: '/two',
- name: 'ChildTwo',
- component: ChildTwo
- }
- ]
- })
- 修改路由导航 <router-link :to="{path:'/one/log',query:{num:123}}"> ,childOne.vue 文件修改如下:
- <template>
- <div style="border:1px solid red;color:red;">
- <p>这是父路由childOne对应的组件页面</p>
- <p>下面可以点击显示嵌套的子路由 </p>
- <router-link :to="{path:'/one/log',query:{num:123}}">显示登录页面</router-link>
- <router-link :to="{path:'/one/reg',query:{num:999}}">显示注册页面</router-link>
- <router-view></router-view>
- </div>
- </template>
- 子路由组件通过 this.$route.query.num 来显示传递过来的参数,reg.vue 文件如下:
- <template>
- <div style="border:1px solid purple;color:purple;">
- <p>注册界面:这是二级路由页面</p>
- <h3>{{this.$route.query.num}}</h3>
- </div>
- </template>
效果如下:
PS: 在第一步的定义路由中我们都使用了mode:history 作用就是去除路由跳转时路由路径前的 “#”
常用的mode模式有两种:
默认为hash模式,最明显的标志是,URL上有#号 localhost:8080/#/,路由会监听#后面的信息变化进行路由匹配
另一种为history模式,不会有#出现,很大程度上对URL进行了美化。需要**注意**history模式在打包后的路由跳转需要服务器配合
默认不使用mode:history 如下
Vue路由传参的几种方式的更多相关文章
- vue路由传参的三种方式以及解决vue路由传参页面刷新参数丢失问题
最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决:Vue中给我们提供了三种路由传参方式,下面我们一个一个的来看一下: 方法一:params传参: this.$r ...
- vue路由传参的三种方式区别(params,query)
最近在做一个项目涉及到列表到详情页的参数的传递,网上搜索一下路由传参,结合自己的写法找到一种适合自己的,不过也对三种写法都有了了解,在此记录一下 <ul class="table_in ...
- vue路由传参的三种方式
方式一 通过query方式传参 这种情况下 query传递的参数会显示在url后面 this.$router.push({ path: '/detail', query: { id: id } }) ...
- vue --- 路由传参的几种方式
方案一: getDescribe(id) { // 直接调用$router.push 实现携带参数的跳转 this.$router.push({ path: `/describe/${id}`, }) ...
- vue路由传参的几种基本方式
原文地址 this.$router.push跳转 现有如下场景,点击父组件的li元素跳转到子组件中,并携带参数,便于子组件获取数据.父组件中: <li v-for="article i ...
- vue-router 路由传参的几种方式,刷新页面参数丢失
常见场景:点击列表详情,跳转到详情内页,传递id参数获取详情数据. 我们先来看看路由跳转的几种方式: 1.通过params方式传参 通过$route.push的path携带参数方式 // 路由配置 { ...
- Vue-router路由传参的三种方式
本文简单介绍下三种路由传参: (1)在路由中配置 { path : ‘/home/:id’, name : ‘Dome’, component } 然后写调用的时候 this.$router.push ...
- vue里面路由传参的三种方式
1.方式一 通过query的方式也就是?的方式路径会显示传递的参数 HTML的方式<router-link :to="{name:xxx,query:{page:1,code:8899 ...
- vue 路由传参的三种基本模式
路由是连接各个页面的桥梁,而参数在其中扮演者异常重要的角色,在一定意义上,决定着两座桥梁是否能够连接成功. 在vue路由中,支持3中传参方式. 场景,点击父组件的li元素跳转到子组件中,并携带参数,便 ...
随机推荐
- java图片处理(加水印、生成缩略图)等之Thumbnailator库
Thumbnailator 是一个为Java界面更流畅的缩略图生成库.从API提供现有的图像文件和图像对象的缩略图中简化了缩略过程,两三行代码就能够从现有图片生成缩略图,且允许微调缩略图生成,同时保持 ...
- windows server2012 R2安装python3.x版本报错0x80240017
windows server2012 R2安装python3.x版本报错0x80240017 环境: windows server 2012 R2系统 问题: 安装python3.5版本时候出现错误0 ...
- Java并发包之阶段执行之CompletionStage接口
前言 CompletionStage是Java8新增得一个接口,用于异步执行中的阶段处理,其大量用在Lambda表达式计算过程中,目前只有CompletableFuture一个实现类,但我先从这个接口 ...
- Linux虚拟内存的作用
要深入了解linux内存运行机制,需要知道下面提到的几个方面:首先,Linux系统会不时的进行页面交换操作,以保持尽可能多的空闲物理内存,即使并没有什么事情需要内存,Linux也会交换出暂时不用的内存 ...
- jdbc如何处理事务
Connection提供了事务处理的方法,通过调用setAutoCommit(false)可以设置手动提交事务:当事务完成后用commit()显式提交事务:如果在事务处理过程中发生异常则通过rollb ...
- 树莓派插入U盘自动拷贝系统日志到U盘或通过U盘升级程序
注意,U盘用Fat32格式,NTFS格式的话,需要在Linux另外安装相应驱动. 可通过udev实现如题的功能. 在/etc/udev/rules.d/目录下新建规则文件98-logcopy.rule ...
- win10系统svn传图片卡死
win10系统svn传图片或者文件有时候会卡死,原因是此种文件的默认打开程序与svn冲突了 svn提交的时候要打开图片,但是图片默认打开程序也要打开 所以冲突了 改下不冲突的默认打开程序就行了 ...
- Apollo环境配置
一.背景 Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限.流程治理等特性,适用于微服务配置管理 ...
- K8S+GitLab+.net core-自动化分布式部署-1
K8S+GitLab-自动化分布式部署ASP.NET Core(一) 部署环境 一.部署流程介绍 开发人员通过Git上传asp.net core 项目到Gilab,并编写好.gitlab-ci.yml ...
- Python MySQLdb 学习总结(转)
转自http://www.cnblogs.com/coser/archive/2012/01/12/2320741.html 感谢@糖拌咸鱼 任何应用都离不开数据,所以在学习python的时候,当然也 ...