【vue2第十七章】VueRouter 编程式导航跳转传参(点击按钮跳转路由和如何传递参数)

news2024/11/19 1:46:48

如何在js进行跳转路由

在一些需求中,我们需要不用点击a标签或者router-link,但是也要实现路由跳转,比如登陆,点击按钮搜索跳转。那么这种情况如何进行跳转呢?
直接再按钮绑定的方法中写this.$router.push('路由路径')即可。
在这里插入图片描述
代码示范 this.$router.push("/跳转路径") 或者 this.$router.push({path:"/跳转路径"})

<template>
    <div>
      <!-- 模板语法获取参数 -->
      <p>我的首页</p>
      <input v-model="ind">
      <button @click="search">搜索</button>
    </div>
  </template>
  <script>
  export default {
    data(){
      return{
        ind:''
      }
    },
    methods:{
      search(){
      //下面两种方式都可以
        // this.$router.push("/fine")
        this.$router.push({
          path:'/fine'
        })
      }
    }
  };
  </script>

还有第二种方法,通过给路由配置名称,在通过名称跳转(使用与path路径较于长的时候):
在这里插入图片描述
这是通过在路由模块配置路由时,为路由增加一个名称属性,这样就可以通过路由名称跳转路径了: {name:'路由名称',path:"/路由路径",component:页面组件},

const router = new VueRouter({
    // mode:"history",
    routes:[
      {path:"/",redirect:'/index'},
      //添加路由名称
      {name:'f',path:"/fine",component:MyFine},
      {path:"/friend",component:MyFriend},
      {path:"/index",component:MyIndex},
      {path:"*",component:NotFind}
    ],
    linkActiveClass:"active",
    linkExactActiveClass:"exact-active"
  });

export default router;

在通过name的值进行跳转:

<template>
    <div>
      <!-- 模板语法获取参数 -->
      <p>我的首页</p>
      <input v-model="ind">
      <button @click="search">搜索</button>
    </div>
  </template>
  <script>
  export default {
    data(){
      return{
        ind:''
      }
    },
    methods:{
      search(){
        this.$router.push({
		//通过路由名称跳转
          name:'f'
        })
      }
    }
  };
  </script>

如何通过 this.$router.push("/跳转路径") 或者 this.$router.push({path:"/跳转路径"})进行传参?

在这里插入图片描述

使用path路径跳转传参两种方式

1. 使用直接在路径后面跟上传递参数

this.$router.push( '/路径?参数名1=参数值1&参数2=参数值2')

代码示范:

<template>
    <div>
      <!-- 模板语法获取参数 -->
      <p>我的首页</p>
      <input v-model="ind">
      <button @click="search">搜索</button>
    </div>
  </template>
  <script>
  export default {
    data(){
      return{
        ind:''
      }
    },
    methods:{
      search(){
      //直接使用?跟参数 &连接多个参数
        this.$router.push("/fine?id=1&name=张三")
      }
    }
  };
  </script>

2.或者使用对象的方式

this.$router.push({
	//使用对象的方式可以将path改为配置的路由name属性
	path:'/路径',
	query:{
	参数名1:参数值1
	参数名2: 参数值2
	}
})

代码示范:

<template>
    <div>
      <!-- 模板语法获取参数 -->
      <p>我的首页</p>
      <input v-model="ind">
      <button @click="search">搜索</button>
    </div>
  </template>
  <script>
  export default {
    data(){
      return{
        ind:''
      }
    },
    methods:{
      search(){
        this.$router.push({
        	//使用对象的方式可以将path改为配置的路由name属性
          path:'/fine',
          //添加query属性直接传参
          query:{
             id:1,
             name:"张三"
          }
        })
      }
    }
  };
  </script>

以上的两种方式传参都是通过 this.$router.query.参数名称在跳转页面获取参数的。

使用path路径的动态路由传参:

1. 使用直接在路径后使用/连接参数值

动态路由传参首先要把路由模块的路由配置改为 {path:"/friend/:参数名?",component:MyFriend},

this.$router.push( '/路径/参数值')

代码示范:

<template>
    <div>
      <!-- 模板语法获取参数 -->
      <p>我的首页</p>
      <input v-model="ind">
      <button @click="search">搜索</button>
    </div>
  </template>
  <script>
  export default {
    data(){
      return{
        ind:''
      }
    },
    methods:{
      search(){
      //直接使用/连接参数
        this.$router.push("/fine/张三")
      }
    }
  };
  </script>

2.或者使用对象的方式

this.$router.push({
	//使用对象的方式可以将path改为配置的路由name属性
	path:'/路径',
	params:{
	参数名1:参数值1
	}
})

代码示范:

<template>
    <div>
      <!-- 模板语法获取参数 -->
      <p>我的首页</p>
      <input v-model="ind">
      <button @click="search">搜索</button>
    </div>
  </template>
  <script>
  export default {
    data(){
      return{
        ind:''
      }
    },
    methods:{
      search(){
        this.$router.push({
       	//使用对象的方式可以将path改为配置的路由name属性
          path:'/fine',
          //添加query属性直接传参
          params:{
             name:"张三"
          }
        })
      }
    }
  };
  </script>

以上的两种方式传参都是通过 this.$router.params.参数名称在跳转页面获取参数的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/983759.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软件兼容性测试怎么做?对软件产品起到什么作用?

软件兼容性测试是一项重要的软件测试活动&#xff0c;它可以确保在不同操作系统、硬件配置和软件环境下&#xff0c;软件能够正常运行&#xff0c;并与其他相关软件和系统进行正确的互动。 一、软件兼容性的测试方法 1、操作系统测试&#xff1a;测试软件在不同操作系统上的兼…

linux常用命令及解释大全(二)

目录 前言 一、文件的权限 二、文件的特殊属性 三、打包和压缩文件 四、查看文件内容 五、文本处理 5.1 grep 5.2 sed 5.3 其它 总结 前言 本篇文章接linux常用命令及解释大全&#xff08;一&#xff09;继续介绍了一部分linux常用命令&#xff0c;包括文件的权限&a…

Android签名查看

查看签名文件信息 第一种方法&#xff1a; 1.打开cmd&#xff0c;执行keytool -list -v -keystore xxx.keystore&#xff0c;效果如下图&#xff1a; 第二种方法: 1.打开cmd&#xff0c;执行 keytool -list -v -keystore xxxx.keystore -storepass 签名文件密码&#xff0…

Linux 下 C语言版本的线程池

目录 1. 线程池引入 2. 线程池介绍 3. 线程池的组成 4. 任务队列 5. 线程池定义 6. 头文件声明 7. 函数实现 8. 测试代码 1. 线程池引入 我们使用线程的时候就去创建一个线程&#xff0c;这样实现起来非常简便&#xff0c;但是就会有一个问题&#xff1a;如果并发的线程数…

壁炉在文学和艺术中的代表着什么呢,能给我们带来什么样的影响?

壁炉&#xff0c;不仅仅是家庭温暖的来源&#xff0c;也是文学和艺术中常见的重要元素。它的形象在文学作品、绘画和电影中频繁出现&#xff0c;不仅为故事情节提供了背景&#xff0c;还象征着情感、温馨和安全感。让我们一起深入探讨壁炉在文学和艺术中的形象&#xff0c;以及…

Android相机调用-CameraX【外接摄像头】【USB摄像头】

Android相机调用有原生的Camera和Camera2&#xff0c;我觉得调用代码都太复杂了&#xff0c;CameraX调用代码简洁很多。 说明文档&#xff1a;https://developer.android.com/jetpack/androidx/releases/camera?hlzh-cn 现有查到的调用资料都不够新&#xff0c;对于外接摄像…

RecyclerView的item布局预览显示是一行两块 运行后显示了一行一块,怎么回事

QQ有人问我了&#xff1a; 没有起作用&#xff1f;有 解决问题&#xff1a;在item布局上第一个外层宽度、高度分别为match_parent和wrap_content&#xff0c;第二个外层宽度和高度都为match_parent&#xff0c;运行后可以显示一行两块 其他学习资料&#xff1a; 1、付费专栏…

mybatis 数据库字段加密

目录 1、引入依赖 2、添加配置 3、指定加密字段 4、测试&#xff0c;效果 1、引入依赖 <dependency><groupId>io.github.whitedg</groupId><artifactId>mybatis-crypto-spring-boot-starter</artifactId><version>1.2.3</version>…

C#文件拷贝工具

目录 工具介绍 工具背景 4个文件介绍 CopyTheSpecifiedSuffixFiles.exe.config DataSave.txt 拷贝的存储方式 文件夹介绍 源文件夹 目标文件夹 结果 使用 *.mp4 使用 *.* 重名时坚持拷贝 可能的报错 C#代码如下 Form1.cs Form1.cs设计 APP.config Program.c…

微信小程序踩坑记录

1、原生微信小程序开发&#xff0c;切换版本后一直报错&#xff0c;切回去还是报错&#xff0c;后来排查发现是编辑器未更新的问题 2、本地开发静态时&#xff0c;要把这个勾选&#xff0c;否则每次提交代码都会冲突 持续记录踩坑。。。

果粉崩溃!Icloud又要涨价?我来教你使用群晖生态将本地SSD“上云“!

文章目录 前言本教程解决的问题是&#xff1a;按照本教程方法操作后&#xff0c;达到的效果是想使用群晖生态软件&#xff0c;就必须要在服务端安装群晖系统&#xff0c;具体如何安装群晖虚拟机请参考&#xff1a; 1. 安装并配置synology drive1.1 安装群辉drive套件1.2 在局域…

Android离线文字识别-tesseract4android调用

Android在线文字识别可以调阿里云的接口Android文字识别-阿里云OCR调用__花花的博客-CSDN博客 需要离线文字识别的话&#xff0c;可以调tesseract4android。个人测试效果不是特别理想&#xff0c;但是速度真的很快&#xff0c;VIVO S10后摄照片&#xff0c;80ms内识别完成。现…

手写Spring:第13章-把AOP扩展到Bean的生命周期

文章目录 一、目标&#xff1a;把AOP扩展到Bean的生命周期二、设计&#xff1a;把AOP扩展到Bean的生命周期三、实现&#xff1a;把AOP扩展到Bean的生命周期3.1 工程结构3.2 AOP动态代理融入Bean的生命周期类图3.3 定义Advice拦截器链3.3.1 定义拦截器链接口3.3.2 方法拦截器链接…

算法笔记:堆

【如无特别说明&#xff0c;皆为最小二叉堆】 1 介绍 2 特性 结构性&#xff1a;符合完全二叉树的结构有序性&#xff1a;满足父节点小于子节点&#xff08;最小化堆&#xff09;或父节点大于子节点&#xff08;最大化堆&#xff09; 3 二叉堆的存储 顺序存储 二叉堆的有序…

问道管理:a股交易时间和规则?

A股是指中国境内流通的人民币普通股票&#xff0c;是国内投资者最为熟悉和广泛的投资工具之一。作为投资者&#xff0c;了解A股的买卖时刻和规矩是非常重要的。本文从买卖时刻、买卖规矩、买卖方式等多个视点来分析A股买卖时刻和规矩&#xff0c;期望对读者有所协助。 A股买卖…

C#事件event

事件模型的5个组成部分 事件拥有者&#xff08;event source&#xff09;&#xff08;类对象&#xff09;&#xff08;有些书将其称为事件发布者&#xff09; 事件成员&#xff08;event&#xff09;&#xff08;事件拥有者的成员&#xff09;&#xff08;事件成员就是事件本身…

2023年03月 C/C++(八级)真题解析#中国电子学会#全国青少年软件编程等级考试

C/C编程&#xff08;1~8级&#xff09;全部真题・点这里 第1题&#xff1a;最短路径问题 平面上有n个点&#xff08;n<100&#xff09;&#xff0c;每个点的坐标均在-10000~10000之间。其中的一些点之间有连线。 若有连线&#xff0c;则表示可从一个点到达另一个点&#xff…

C++——STL容器【map和set】

文档&#xff1a;map、set 文章目录 &#x1f36f;1. 关联式容器&#x1fad6;2. set&#x1f37c;1. 模板参数&#x1f37c;2. 构造函数&#x1f37c;3. 修改&#x1f37c;4.操作&#x1f95b;find&#x1f95b;count&#x1f95b;lower_bound & upper_bound & equal_…

Increment Selection 插件

Increment Selection 插件实现递增 初次使用 按下快捷键 Alt Shift 鼠标左键向下拖拽 向下拖拽之后&#xff0c;在输入一个数字&#xff0c;比如我这里输入了一个数字1 然后按下快捷键 Ctrl Shift ← 进行选中数字 然后按下快捷键 Ctrl Alt i 建自动递增。 然后鼠标随…

网络是如何进行通信

网络是如何进行通信的 简介 在现代社会中&#xff0c;网络已经成为我们生活中不可或缺的一部分。从上网搜索信息、在线购物到远程工作和社交媒体&#xff0c;我们几乎无时无刻不与网络保持着联系。但是&#xff0c;网络究竟是个什么玩意&#xff0c;它是如何工作的呢&#xf…