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路由跳转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue如何通过button的disabled控制按钮能否被使用

    vue如何通过button的disabled控制按钮能否被使用

    这篇文章主要介绍了vue如何通过button的disabled控制按钮能否被使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • vue视图不更新情况详解

    vue视图不更新情况详解

    这篇文章主要介绍了vue视图不更新情况详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • Ant Design of Vue select框获取key和name的问题

    Ant Design of Vue select框获取key和name的问题

    这篇文章主要介绍了Ant Design of Vue select框获取key和name的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • Vue监视数据的原理详解

    Vue监视数据的原理详解

    这篇文章主要为大家详细介绍了Vue监视数据的原理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • vue使用elementUI组件实现分页效果

    vue使用elementUI组件实现分页效果

    分页在展示数据列表的场景肯定是非常多的,一般的项目开发中,数据量特别大,一般都是后端接口直接处理分页返回,前端直接调用即可,本文给大家介绍了vue使用elementUI组件实现分页效果,需要的朋友可以参考下
    2023-12-12
  • Vue.js原理分析之observer模块详解

    Vue.js原理分析之observer模块详解

    这篇文章主要介绍了Vue.js中observer模块的相关资料,文中通过原理分析介绍还是相对的详细,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-02-02
  • vue中$refs的用法及作用详解

    vue中$refs的用法及作用详解

    这篇文章主要介绍了vue中$refs的用法及作用详解,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-04-04
  • 使用Vue实现网页截图和截屏功能

    使用Vue实现网页截图和截屏功能

    网页截图与截屏功能在许多Web应用程序中都非常有用,Vue.js作为一个流行的JavaScript框架,提供了许多工具和库来简化网页截图和截屏的实现,本文将介绍如何使用Vue来实现一个网页截图和截屏功能的示例,包括使用html2canvas库和vue-cropper库,需要的朋友可以参考下
    2023-10-10
  • vue之debounce属性被移除及处理详解

    vue之debounce属性被移除及处理详解

    今天小编就为大家分享一篇vue之debounce属性被移除及处理详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • vue如何安装使用Quill富文本编辑器

    vue如何安装使用Quill富文本编辑器

    这篇文章主要为大家详细介绍了vue如何安装使用Quill富文本编辑器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09

最新评论