Vues中使用JavaScript实现路由跳转的步骤详解

 更新时间:2024年05月10日 10:07:49   作者:好奇的菜鸟  
在Vue应用中,利用Vue Router进行页面间的导航是一个常见需求,本篇博客将通过示例代码详细介绍如何在Vue组件中使用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中的参数还是直接展现在查询字符串中的参数,都能轻松应对。

到此这篇关于Vues中使用JavaScript实现路由跳转详解的文章就介绍到这了,更多相关Vue JavaScript路由跳转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用el-table做成树形结构并解决数据驱动视图问题

    使用el-table做成树形结构并解决数据驱动视图问题

    这篇文章主要介绍了使用el-table做成树形结构并解决数据驱动视图问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • 详解vee-validate的使用个人小结

    详解vee-validate的使用个人小结

    本篇文章主要介绍了详解vee-validate的使用个人小结,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-06-06
  • Vue3子组件实现v-model用法的示例代码

    Vue3子组件实现v-model用法的示例代码

    在Vue 3中,实现自定义的input组件并支持v-model绑定,涉及到对modelValue这个默认prop的处理和对应的update:modelValue事件的触发,本文给大家介绍了Vue3子组件实现v-model用法的示例,需要的朋友可以参考下
    2024-04-04
  • vue动态禁用控件绑定disable的例子

    vue动态禁用控件绑定disable的例子

    今天小编就为大家分享一篇vue动态禁用控件绑定disable的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • VUE自动化部署全过程

    VUE自动化部署全过程

    本文介绍了使用scp2库将构建后的文件上传到生产或测试环境的方案,包括安装scp2、编写环境脚本、忽略脚本、添加npm脚本命令及执行步骤,该方法简便但不够安全,适合快速部署
    2025-11-11
  • vue 支持百万量级的无限滚动组件详解

    vue 支持百万量级的无限滚动组件详解

    这篇文章主要为大家介绍了vue 支持百万量级的无限滚动组件详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 使用Vue 自定义文件选择器组件的实例代码

    使用Vue 自定义文件选择器组件的实例代码

    这篇文章主要介绍了使用Vue 自定义文件选择器组件的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • Element的穿梭框数据量大时点击全选卡顿的解决方案

    Element的穿梭框数据量大时点击全选卡顿的解决方案

    本文主要介绍了Element的穿梭框数据量大时点击全选卡顿的解决方案,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • vscode中eslint配置保存自动修复代码示例详解

    vscode中eslint配置保存自动修复代码示例详解

    vscode根据eslint保存⾃动修复配置,下面这篇文章主要给大家介绍了关于vscode中eslint配置保存自动修复代码的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • vue项目添加多页面配置的步骤详解

    vue项目添加多页面配置的步骤详解

    公司使用 vue-cli 创建的 vue项目 在初始化时并没有做多页面配置,随着需求的不断增加,发现有必要使用多页面配置。这篇文章主要介绍了vue项目添加多页面配置,需要的朋友可以参考下
    2019-05-05

最新评论