当前位置: 首页 > news >正文

Vue.js中使用JavaScript实现路由跳转详解

在Vue应用中,利用Vue Router进行页面间的导航是一个常见需求。本篇博客将通过示例代码详细介绍如何在Vue组件中使用JavaScript实现路由跳转,包括传递参数的两种方式:通过paramsquery。让我们一步步深入了解。

基础设置

首先,确保你的项目中已安装并配置了Vue Router。一个基本的Vue Router配置可能如下所示(在router/index.js文件中):

import Vue from 'vue'
import Router from 'vue-router'
import Seq from '@/components/Seq'Vue.use(Router)export default new Router({routes: [{path: '/rd/proj/seq',name: 'Seq',component: Seq},// 其他路由配置...]
})

使用模板内的方法实现跳转

模板部分

在Vue组件的模板中,你可以定义一个按钮,其点击事件会触发一个函数来执行路由跳转。

<template><div><button @click="navigateToSeq">跳转到Seq页面</button></div>
</template>

脚本部分

在脚本部分,我们定义navigateToSeq方法来使用this.$router.push进行路由跳转。这里,我们将展示如何传递参数。

使用params传递参数

如果你希望在URL路径中不显示参数,可以使用params

<script>
export default {methods: {navigateToSeq() {const row = { contractNo: '123' }; // 假设这是从某个地方获取的数据this.$router.push({ name: 'Seq', params: { contractNo: row.contractNo } });}}
}
</script>

注意,使用params时,接收参数需要在目标组件的beforeRouteUpdate钩子或通过this.$route.params.contractNo访问。

使用query传递参数

如果你想在URL中以查询字符串的形式显示参数,应该使用query

<script>
export default {methods: {navigateToSeq() {const row = { contractNo: '123' };this.$router.push({ path: '/rd/proj/seq', query: { contractNo: row.contractNo } });}}
}
</script>

使用query时,可以通过this.$route.query.contractNo获取参数值。

在目标组件中接收参数

接收params

对于通过params传递的参数,在目标组件(Seq.vue)中,你可以在createdmounted生命周期钩子,或者使用watch来监听$route的变化来获取参数。

export default {created() {console.log(this.$route.params.contractNo); // 访问通过params传递的合同编号}
}
接收query

对于query参数,获取方式与params相同:

export default {created() {console.log(this.$route.query.contractNo); // 访问通过query传递的合同编号}
}

通过上述步骤,你可以在Vue应用中灵活地使用JavaScript实现页面之间的路由跳转及参数传递,无论是隐藏在URL中的参数还是直接展现在查询字符串中的参数,都能轻松应对。

http://www.lryc.cn/news/346216.html

相关文章:

  • 社群裂变:从微光到星火的社群增长奥秘
  • Git命令Gitee注册idea操作git超详细
  • 出差行程到底怎么管?这个“高分指南”划重点来了!
  • js设计模式--发布订阅者模式
  • 【图论】图论基础
  • Konga域名配置多个路由
  • 15.计算机网络
  • 【大数据·hadoop】在hdfs上运行shell基本常用命令
  • TCP/IP 协议基础:构建互联网基石
  • Android OpenMAX(三)高通OMX组件实现基础
  • 【比邻智选】MF871U模组
  • Unity 单例模式
  • Oracle-一次TX行锁堵塞事件
  • Gtid方式搭建主从复制+MHA高可用集群
  • 基于matlab GUI的Alpha shapes边缘提取
  • [Android]常见的包管理方式
  • 每日10亿数据的日志分析系统OOM
  • 智能驱动,精准管理:打造高效干部管理系统
  • 轮式机器人简介
  • 已知哈夫曼节点个数,求哈夫曼字符编码数
  • Kubernetes Cluster IP,Node IP,Pod IP间通信原理解析
  • 随机链表的深拷贝
  • 328_C++_HTTP_HTTP协议传输data数据,为什么要进行base64编解码操作?
  • 【二叉树】Leetcode N 叉树的层序遍历
  • Spring AI
  • fiori SAP ui5 动态改变控件颜色
  • RabbitMQ php amqp
  • 对称二叉树
  • 浅浅总结SQL中的事务.
  • C++ | Leetcode C++题解之第76题最小覆盖子串