Vue-router 3.x 参数传递看完让你明明白白!

这篇具有很好参考价值的文章主要介绍了Vue-router 3.x 参数传递看完让你明明白白!。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

概述

Vue- routrer,页面路由跳转时,携带参数传递 并拿取传递过来的参数,本文将详细讲解 Vue router传递参数的多种方式;
如果你还不了解 Vuerouter 基本使用及配置请通过下面传送门,了解vue router 路由的基本配置及使用
传送门去了解 Vue-router

路由传参的两大载体分类

声明式路由 【router-link 】

编程式路由 【this.$router.push()】

传参的方式

1. 通过 params 传递参数

params参数传递也有两种方式:第一种就是在路由路径 path 后面 添加接收参数的字段占位传参,第二种 就是不需要配置占位字段也能传参

配置路由参数字段占位(编程式路由实现)

//路由中配置
  {
    path: '/datapage/:id',   //若id后面加?代表这个参数是可选非必传的,即使不传id也不会导致页面无法访问
    name: 'datapage',
    component: datapage,
    children: [],
  },

//页面中跳转
  this.$router.push({
      path: `/datapage/${"参数"}`,       //如果要是用 path 传参 必须使用字符串模板    
  });

//或
  this.$router.push({       //如果要是用 name 传参 就直接 携带一个 params 对象中包含参数  
      name: "datapage",
      params:{
          id:"参数字段"
      }
  });

//目标页面中,读取出参数
this.$route.params.id

配置路由参数字段占位(声明式路由实现)

<!-- routerlink   采用 字符串模板来进行传递参数 -->
 <router-link :to=" `/datapage/${123456}` ">跳转</router-link>
<!-- 或 使用命名路由-->
 <router-link :to="{  name:  'datapage',  params:  {  id:  789787  }  }">跳转</router-link>

无需配置路由参数字段占位(编程式路由实现)

  this.$router.push({       //如果未在路由中配置接收参数字段,还要传递 params 参数, 就只能必须使用 name 进行跳转
      name: "datapage",
      params:{
          id:"参数字段"
      }
  });
//目标页面中,读取出参数
this.$route.params.id

无需配置路由参数字段占位(声明式路由实现)

<!-- 未定义路由路径字段,就必须使用  name 跳转传参 -->
 <router-link :to="{  name:  'datapage',  params:  {  id:  789787  }  }">跳转</router-link>

**注明**

同样都是 params 传参 在路由路径中定义 字段接收占位 和不定义字段 接受的区别 是什么?
答:定义字段路径是因为 参数 是以 路径的形式跟在URL 后面的,这样一来,即使浏览器页面刷新了过后参数也不会丢失。反之如果未配置接收参数字段,虽然参数依然能够正常传递,参数在URL中也不会显示,但是当页面或者浏览器刷新后,当前页面携带过来的参数会造成丢失。

2. 通过 query 传递参数

通过router-link 传递 query 参数

   <!-- 通过path 在路径后面跟 ? 加上参数字段名 -->
  <router-link :to="`/datapage?id=${'我是query传递的参数'}`">跳转</router-link>
          <!-- 或者 使用 命名路由传参 ,直接跟一个 query 对象携带参数-->
  <router-link :to="{ name: 'datapage', query: { id: '参数' } }">跳转</router-link>
          <!-- 还可以使用 path 对象 传参-->
  <router-link :to="{ path: '/datapage', query: { id: '参数66' } }">跳转</router-link>

routerlink传递参数,Vue Router,vue.js,javascript,前端,前端框架

通过 编程式路由 传递 query 参数

 this.$router.push({
     name: "datapage",
     query: {
         id: "我叫蜘蛛侠"
     }
 });


this.$router.push({
     path: "/datapage",
     query: {
         id: "我叫蜘蛛侠"
     }
 });
//页面中读取数据
this.$route.query.id

**注明**

query 方式传参,无需在路由配置文件中配置参数占位,参数是以 ?id 跟在url 后面的,页面刷新后,参数也不会丢失

补充说明:

如果 query 传递的参数是数组或者对象,地址栏中的参数会被转换成 [object Object] ,页面刷新后,读取不到参数值, 这里建议在传递 数组或对象的参数前,通过 JSON.stringify() 对数据进行序列化处理,目标页面拿到参数后,再进行反序列化即可。

3.使用 props 属性代理传递参数

前言:
有时候,当我们传递页面的数据过多的时候,目标页面内会出现大量的 this.$route.query 或者 this.$route.params 进行参数解构,还可能出现 多项 计算属性解构,这样页面会显得代码很冗杂
所以这时候 就可以使用 props 代理接收参数

在目标页面中定义好 Props 及要接收的参数名

<template>
  <div>
    <h1>{{ id }}</h1>
    <h1>{{ name }}</h1>
    <h1>{{ title }}</h1>
  </div>
</template>

<script>
export default {
  data() {
    return {

    }
  },
  props: ["id", "name", "title"],
}
</script>

在路由配置中

{
    path: '/datapage',
    name: 'datapage',
    component: datapage,
    children: [],

    // 第一种方式
    // props: { id: 1, name: "张三", title: "标题" }    直接给props 赋值,这时候的值是写死的静态数据
    // 第二种方式
    // props:true                          //如果props 设置为true 时,则会默认把props,映射到  params 参数上。

    //那么如果,我既要接收params 参数又要 接收 query  参数,通过 props 应该怎么实现呢?

    // 第三种方式  props 是一个函数   接收一个参数  可以拿到整个 route 实例对象,所有的 params  和 query  参数都可以在实例上拿取到

   props(route) {
      console.log(route);
      const { a } = route.params
      const { names } = route.params
      const { titles } = route.query
      return { id: a, name: names, title: titles }          //拿取到对应的值后,再整合到相应的字段格式上,返回数据
    }
  },

routerlink传递参数,Vue Router,vue.js,javascript,前端,前端框架

补充点

如果有这么一个需求,在我通过路由传递参数到目标页面的时候,我的目标页面需要对这个参数向后端进行请求校验,查看是否合法,也就是说,需要在路由传递参数的时候开启异步任务。

路由跳转时,传递的参数
routerlink传递参数,Vue Router,vue.js,javascript,前端,前端框架

<template>
  <div>
    <h1>{{ id }}</h1>
    <h1>{{ name }}</h1>
    <h1>{{ title }}</h1>
  </div>
</template>

<script>


export default {
  data() {
    return {
      name: '',    //假设我需要对传递过来的name 参数进行加工,校验处理,首先我们把,原本props 接收name 的参数,拿走,定义到data 中来。
    }
  },
  props: ["id", "title"],
  watch: {         //然后,采用  watch 数据监视,监视每一次路由传递参数的变化,并且能够拿到参数
    $route: {
      immediate: true,
      deep: true,
      handler(route) {
        setTimeout(() => {      //开启异步任务,对某一条数据进行加工处理。
          this.name = route.params.name + '____校验完成';
        }, 3000)
      }
    }
  },
}
</script>

点我了解watch 数据监视
routerlink传递参数,Vue Router,vue.js,javascript,前端,前端框架文章来源地址https://www.toymoban.com/news/detail-735851.html

到了这里,关于Vue-router 3.x 参数传递看完让你明明白白!的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue-router笔记

    目的:为了实现SPA(单页面应用) vue-router是一个插件库 安装: 路由的配置路径:/src/router/index.js 路由组件的目录:/src/pages/ 一般组件的目录:/src/components/ 使用: main.js: App.vue: About.vue: 不可见的路由组件在哪?        被销毁了 嵌套路由的案例: 路由传参: query: 传参

    2024年02月12日
    浏览(36)
  • 【Vue-Router】别名

    后台返回来的路径名不合理,但多个项目在使用中了,不方便改时可以使用别名。可以有多个或一个。 First.vue Second.vue , Third.vue 代码同理 UserSettings.vue index.ts App.vue

    2024年02月12日
    浏览(34)
  • 路由vue-router

    路由(英文:router)就是 对应关系 SPA 指的是一个 web 网站只有 唯一的一个 HTML 页面 ,所有组件的展示与切换都在这唯一的一个页面内完成。 此时,不同组件之间的切换需要通过前端路由来实现。 结论: 在 SPA 项目中,不同功能之间的切换 ,要依赖于 前端路由 来完成!

    2024年02月07日
    浏览(32)
  • Vue-Router基本使用

    1 安装: vue2项目要安装vue-router@3版本 npm i vue-router@3 2 src下创建router目录,router文件夹下创建index.js 在vue.config.js中 配置src路径别名  3 在main.js中引入 4 在app.vue中配置  5 即可看到内容    

    2024年02月15日
    浏览(25)
  • 【Vue-Router】命名视图

    同时 (同级) 展示多个视图,而不是嵌套展示,例如创建一个布局,有 sidebar (侧导航) 和 main (主内容) 两个视图,这个时候命名视图就派上用场了。 可以在界面中拥有多个单独命名的视图,而不是只有一个单独的出口。 如果 router-view 没有设置名字,那么默认为 default。一个视

    2024年02月13日
    浏览(31)
  • 【Vue-Router】路由入门

    路由(Routing)是指确定网站或应用程序中特定页面的方式。在Web开发中,路由用于根据URL的不同部分来确定应用程序中应该显示哪个内容。 构建前端项目 安装依赖和路由 3. router 使用 login.vue reg.vue index.ts App.vue main.ts router-view 补充: router-view 是Vue Router提供的一个组件,用于

    2024年02月13日
    浏览(28)
  • vue-router路由守卫

    在我们使用vue-router的时候,路由守卫就像监听器、拦截器一样,帮我们做一些鉴权等操作,vue中的路由守卫分为全局路由守卫、独享路由守卫、组件内的路由守卫 全局路由守卫 : beforeEach、 afterEach 组件独享路由守卫 :beforeEnter、 beforeLeave 组件内路由守卫 :beforeRouteEnter、

    2024年02月11日
    浏览(31)
  • vue-router路由模式详解

    目录 一. vue-router(前端路由)有两种模式,hash模式和history模式 二、路由模式解析 三、两种模式的区别 1、hash模式  2、history路由 (3)popstate实现history路由拦截,监听页面返回事件 一. vue-router(前端路由)有两种模式,hash模式和history模式 1.hash 就是指 url 后面的 # 号以及后

    2024年02月03日
    浏览(62)
  • Vue-Router相关理解4

    两个新的生命周期钩子 activated 和 deactivated 是路由组件所独有的两个钩子,用于捕获路由组件的激活状态具体使用 activated 路由组件被 激活 时触发 deactivated 路由组件 失活 时触发   src/pages/News.vue 路由守卫 对路由权限进行控制 meta元数据对象 全局路由守卫 src/router/index.js 独享

    2024年02月16日
    浏览(36)
  • vue-router钩子执行顺序

    Vue的路由在执行跳转时,根据源码可知,调用了router中定义的navigate函数 由上述源码中可以看出,由Promise then的链式调用保证了路由守卫按照以下顺序执行: 旧的路由组件 beforeRouteLeave 全局配置的 beforeEach 复用的路由组件 beforeRouteUpdate 新路由的 beforeEnter 新路由组件的 befor

    2024年02月15日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包