Vue路由传参的几种方式

2018年07月28日 23:52:40 广积粮缓称王 阅读数 12613
 

前言:顾名思义,vue路由传参是指嵌套路由时父路由向子路由传递参数,否则操作无效。传参方式可以划分为params传参和query传参,params传参又可以分为url中显示参数和不显示参数两种方式。具体区分和使用后续分析。

参考官网:https://router.vuejs.org/zh/guide/essentials/navigation.html

params传参(url中显示参数)

  • 文件结构

  • 定义路由:在定义path路由路径时定义参数名和格式,如  path: "/one/login/:num" ,router>index.js文件如下
  1.  
    /* eslint-disable*/
  2.  
     
  3.  
    //第一步:引用vue和vue-router ,Vue.use(VueRouter)
  4.  
    import Vue from 'vue'
  5.  
    import Router from 'vue-router'
  6.  
    Vue.use(Router)
  7.  
     
  8.  
    //第二步:引用定义好的路由组件
  9.  
    import ChildOne from '../components/childOne'
  10.  
    import ChildTwo from '../components/childTwo'
  11.  
    import Log from '../components/log.vue'
  12.  
    import Reg from '../components/reg.vue'
  13.  
     
  14.  
    //第三步:定义路由(路由对象包含路由名、路径、组件、参数、子路由等),每一个路由映射到一个组件
  15.  
    //第四步:通过new Router来创建router实例
  16.  
    export default new Router({
  17.  
    mode: 'history',
  18.  
    routes: [
  19.  
    {
  20.  
    path: '/one',
  21.  
    name: 'ChildOne',
  22.  
    component: ChildOne,
  23.  
    children:[
  24.  
    {
  25.  
    path:'/one/log/:num',
  26.  
    component:Log,
  27.  
    },
  28.  
    {
  29.  
    path:'/one/reg/:num',
  30.  
    component:Reg,
  31.  
    },
  32.  
    ],
  33.  
    },
  34.  
    {
  35.  
    path: '/two',
  36.  
    name: 'ChildTwo',
  37.  
    component: ChildTwo
  38.  
    }
  39.  
    ]
  40.  
    })
  • 在父路由组件上使用router-link进行路由导航,传参用<router-link to="/one/login/001">的形式向子路由组件传递参数。使用router-view进行子路由页面内容渲染,父路由组件childOne.vue 如下:
  1.  
    <template>
  2.  
    <div style="border:1px solid red;color:red;">
  3.  
    <p>这是父路由childOne对应的组件页面</p>
  4.  
    <p>下面可以点击显示嵌套的子路由 </p>
  5.  
    <router-link to="/one/log/123">显示登录页面</router-link>
  6.  
    <router-link to="/one/reg/002">显示注册页面</router-link>
  7.  
    <router-view></router-view>
  8.  
    </div>
  9.  
    </template>
  • 子路由通过 this.$route.params.num 的形式来获取父路由向子路由传递过来的参数,子路由组件login.vue如下:
  1.  
    <template>
  2.  
    <div style="border:1px solid orange;color:orange;">
  3.  
    <p>登录界面:这是另一个嵌套路由的内容</p>
  4.  
    <h3>{{this.$route.params.num}}</h3>
  5.  
    </div>
  6.  
    </template>

效果:

注意:如上所述路由定义的path: "/one/login/:num"路径和to="/one/login/001"必须书写正确,否则不断点击切换路由,会因为不断将传递的值显示添加到url中导致路由出错,如下

传递的值存在url中存在安全风险,为防止用户修改,另一种方式不在url中显示传递的值

params传参(url中不显示参数)

  • 定义路由时添加name属性给映射的路径取一个别名,router>index.js文件修改router如下:
  1.  
    export default new Router({
  2.  
    mode: 'history',
  3.  
    routes: [
  4.  
    {
  5.  
    path: '/one',
  6.  
    name: 'ChildOne',
  7.  
    component: ChildOne,
  8.  
    children:[
  9.  
    {
  10.  
    path:'/one/log/',
  11.  
    name:'Log',
  12.  
    component:Log,
  13.  
    },
  14.  
    {
  15.  
    path:'/one/reg/',
  16.  
    name:'Reg',
  17.  
    component:Reg,
  18.  
    },
  19.  
    ],
  20.  
    },
  21.  
    {
  22.  
    path: '/two',
  23.  
    name: 'ChildTwo',
  24.  
    component: ChildTwo
  25.  
    }
  26.  
    ]
  27.  
    })
  • 在父路由组件上使用router-link进行路由导航,使用   <router-link :to="{name:'home',params:{id:001}}>    形式传递参数。注意   ': to= ' 前面的冒号,childOne.vue组件修改如下:
  1.  
    <template>
  2.  
    <div style="border:1px solid red;color:red;">
  3.  
    <p>这是父路由childOne对应的组件页面</p>
  4.  
    <p>下面可以点击显示嵌套的子路由 </p>
  5.  
    <router-link :to="{name:'Log',params:{num:666}}">显示登录页面</router-link>
  6.  
    <router-link :to="{name:'Reg',params:{num:888}}">显示注册页面</router-link>
  7.  
    <router-view></router-view>
  8.  
    </div>
  9.  
    </template>
  • 子路由组件页面获取父路由传参方式不变,reg.vue 文件如下:
  1.  
    <template>
  2.  
    <div style="border:1px solid orange;color:orange;">
  3.  
    <p>登录界面:这是另一个嵌套路由的内容</p>
  4.  
    <h3>子路由获取的参数:{{this.$route.params.num}}</h3>
  5.  
    </div>
  6.  
    </template>

注意:上述这种利用params不显示url传参的方式会导致在刷新页面的时候,传递的值会丢失;

使用Query实现路由传参

  • 定义路由 router>index.js文件如下:
  1.  
    export default new Router({
  2.  
    mode: 'history',
  3.  
    routes: [
  4.  
    {
  5.  
    path: '/one',
  6.  
    name: 'ChildOne',
  7.  
    component: ChildOne,
  8.  
    children:[
  9.  
    {
  10.  
    path:'/one/log/',
  11.  
    component:Log,
  12.  
    },
  13.  
    {
  14.  
    path:'/one/reg/',
  15.  
    component:Reg,
  16.  
    },
  17.  
    ],
  18.  
    },
  19.  
    {
  20.  
    path: '/two',
  21.  
    name: 'ChildTwo',
  22.  
    component: ChildTwo
  23.  
    }
  24.  
    ]
  25.  
    })
  • 修改路由导航 <router-link :to="{path:'/one/log',query:{num:123}}"> ,childOne.vue 文件修改如下:
  1.  
    <template>
  2.  
    <div style="border:1px solid red;color:red;">
  3.  
    <p>这是父路由childOne对应的组件页面</p>
  4.  
    <p>下面可以点击显示嵌套的子路由 </p>
  5.  
    <router-link :to="{path:'/one/log',query:{num:123}}">显示登录页面</router-link>
  6.  
    <router-link :to="{path:'/one/reg',query:{num:999}}">显示注册页面</router-link>
  7.  
    <router-view></router-view>
  8.  
    </div>
  9.  
    </template>
  • 子路由组件通过 this.$route.query.num 来显示传递过来的参数,reg.vue 文件如下:
  1.  
    <template>
  2.  
    <div style="border:1px solid purple;color:purple;">
  3.  
    <p>注册界面:这是二级路由页面</p>
  4.  
    <h3>{{this.$route.query.num}}</h3>
  5.  
    </div>
  6.  
    </template>

效果如下:

PS: 在第一步的定义路由中我们都使用了mode:history 作用就是去除路由跳转时路由路径前的 “#”

常用的mode模式有两种:

默认为hash模式,最明显的标志是,URL上有#号 localhost:8080/#/,路由会监听#后面的信息变化进行路由匹配

另一种为history模式,不会有#出现,很大程度上对URL进行了美化。需要**注意**history模式在打包后的路由跳转需要服务器配合

默认不使用mode:history 如下

Vue路由传参的几种方式的更多相关文章

  1. vue路由传参的三种方式以及解决vue路由传参页面刷新参数丢失问题

    最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决:Vue中给我们提供了三种路由传参方式,下面我们一个一个的来看一下: 方法一:params传参: this.$r ...

  2. vue路由传参的三种方式区别(params,query)

    最近在做一个项目涉及到列表到详情页的参数的传递,网上搜索一下路由传参,结合自己的写法找到一种适合自己的,不过也对三种写法都有了了解,在此记录一下 <ul class="table_in ...

  3. vue路由传参的三种方式

    方式一 通过query方式传参 这种情况下 query传递的参数会显示在url后面 this.$router.push({ path: '/detail', query: { id: id } }) ...

  4. vue --- 路由传参的几种方式

    方案一: getDescribe(id) { // 直接调用$router.push 实现携带参数的跳转 this.$router.push({ path: `/describe/${id}`, }) ...

  5. vue路由传参的几种基本方式

    原文地址 this.$router.push跳转 现有如下场景,点击父组件的li元素跳转到子组件中,并携带参数,便于子组件获取数据.父组件中: <li v-for="article i ...

  6. vue-router 路由传参的几种方式,刷新页面参数丢失

    常见场景:点击列表详情,跳转到详情内页,传递id参数获取详情数据. 我们先来看看路由跳转的几种方式: 1.通过params方式传参 通过$route.push的path携带参数方式 // 路由配置 { ...

  7. Vue-router路由传参的三种方式

    本文简单介绍下三种路由传参: (1)在路由中配置 { path : ‘/home/:id’, name : ‘Dome’, component } 然后写调用的时候 this.$router.push ...

  8. vue里面路由传参的三种方式

    1.方式一 通过query的方式也就是?的方式路径会显示传递的参数 HTML的方式<router-link :to="{name:xxx,query:{page:1,code:8899 ...

  9. vue 路由传参的三种基本模式

    路由是连接各个页面的桥梁,而参数在其中扮演者异常重要的角色,在一定意义上,决定着两座桥梁是否能够连接成功. 在vue路由中,支持3中传参方式. 场景,点击父组件的li元素跳转到子组件中,并携带参数,便 ...

随机推荐

  1. 【mybatis源码学习】mybatis的反射模块

    一.重要的类和接口 org.apache.ibatis.reflection.MetaClass//对于javaBean的calss类进行反射操作的代理类(获取属性的类型,获取属性的get,set方法 ...

  2. 人物-IT-李想:百科

    ylbtech-人物-IT-李想:百科 李想,1981年10月出生于河北石家庄,80后企业家代表人物.曾先后创立泡泡网.汽车之家,现任车和家创始人及CEO. 1998年还在上高中的李想就开始做个人网站 ...

  3. JAVA Asponse.Word Office 操作神器,借助 word 模板生成 word 文档,并转化为 pdf,png 等多种格式的文件

    一,由于该 jar 包不是免费的, maven 仓库一般不会有,需要我们去官网下载并安装到本地 maven 仓库 1,用地址   https://www-evget-com/product/564  ...

  4. exports module.exports export export default之间的关系

    exports 和module.exports是CommonJS模块规范 export export default是ES6模块的规范,两者完全是不同的概念. node应用由模块组成,采用的是Comm ...

  5. [LeetCode] 140. Word Break II 单词拆分II

    Given a non-empty string s and a dictionary wordDict containing a list of non-empty words, add space ...

  6. 使用office365 world2016发布编辑备份你的博客

    开门见山.   如果你曾使用过live writer或者world 2013及之前版本发布过博客,那么请直接异步到最后的tips来查找你可能遇到的问题.     在office365中找到博客模板 打 ...

  7. 【视频开发】RTSP SERVER(基于live555)详细设计

    /* *本文基于LIVE555的嵌入式的RTSP流媒体服务器一个设计文档,个中细节现剖于此,有需者可参考指正,同时也方便后期自己查阅.(本版本是基于2011年的live555) 作者:llf_17@q ...

  8. SpringBoot读取properties中的属性值

    1.在application.properties中添加以下内容: learn.blog.name=hello learn.blog.title=千回教育系统 2.新增属性关联的类: package ...

  9. PLSQL Developer 11 使用技巧(持续更新)

    PLSQL Developer 11 使用技巧 (持续更新) 目录(?)[-] 首先是我的颜色配置 常用快捷键 提升PLSQL编程效率 按空格自动替换 关闭Window窗口 PLSQL 实用技巧 TI ...

  10. Mac打开原生NTFS功能

    一.在 terminal 里输入 diskutil list 查看 U 盘的 NAME diskutil list 二.执行以下命令,输入密码 sudo nano /etc/fstab 三.把U盘信息 ...