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

router.push()

下面,我们来系统的梳理关于 Vue Router router.push() 的基本知识点:


一、router.push() 核心概念

1.1 什么是 router.push()

router.push() 是 Vue Router 提供的编程式导航方法,用于在 JavaScript 中以编程方式导航到新的 URL,同时向浏览器的历史记录栈添加一条新记录。

1.2 与声明式导航的对比

特性<router-link> (声明式)router.push() (编程式)
使用场景模板中直接使用JavaScript 代码中使用
灵活性基本导航需求复杂导航逻辑
事件处理通过点击触发可在任何事件或条件中触发
历史记录添加新记录添加新记录
参数传递支持支持更复杂的参数组合

1.3 核心作用

  1. 导航到新路由:改变当前 URL 并渲染对应组件
  2. 添加历史记录:用户可通过浏览器后退按钮返回
  3. 传递参数:支持路径参数、查询参数和哈希
  4. 条件导航:在导航前执行验证逻辑

二、基本使用方法

2.1 字符串路径

// 导航到绝对路径
router.push('/home')// 导航到相对路径
router.push('about') // 基于当前路径// 带查询参数
router.push('/search?query=vue')

2.2 对象形式(推荐)

// 使用路径
router.push({ path: '/user/123' })// 使用命名路由
router.push({ name: 'userProfile', params: { id: 123 } })// 带查询参数
router.push({path: '/register',query: { plan: 'premium' }
})// 带哈希值
router.push({ path: '/about', hash: '#team' })

2.3 带参数的命名路由

// 定义路由
{path: '/user/:id',name: 'user',component: User
}// 导航方式
router.push({ name: 'user', params: { id: 123 } })// 错误:提供 path 时 params 会被忽略
router.push({ path: '/user', params: { id: 123 } }) // -> /user

三、参数传递详解

3.1 路径参数 (params)

// 路由配置
{ path: '/user/:id', name: 'user', component: User }// 导航
router.push({ name: 'user', params: { id: 123 } }) // -> /user/123// 在组件中访问
this.$route.params.id // 123

3.2 查询参数 (query)

// 导航
router.push({path: '/search',query: { q: 'vue', page: 2 }
}) // -> /search?q=vue&page=2// 在组件中访问
this.$route.query.q // 'vue'
this.$route.query.page // '2'

3.3 哈希 (hash)

router.push({path: '/documentation',hash: '#installation'
}) // -> /documentation#installation// 在组件中访问
this.$route.hash // '#installation'

3.4 参数组合使用

router.push({name: 'productDetail',params: 
http://www.dtcms.com/a/251379.html

相关文章:

  • 【Java】网络编程基础与聊天室架构分析
  • 七 医学影像云平台-影像检验互联互认平台建设中遇到的问题
  • to avoid naming wrong index webpage for one website
  • 安卓9.0系统修改定制化____安卓9.0系统精简 了解系统app组件构成 系统app释义 常识篇 一
  • 前端api中使用data传参源码解释
  • InnoDB的undo日志的数据结构
  • 跨域问题之前后端解决办法
  • 中介者模式Mediator Pattern
  • NISP-PTE基础实操——SQL注入
  • Vue3 Pinia Store 生命周期管理
  • Mysql基础入门\期末速成
  • 5G NR PDCCH之CORESET交织映射
  • 25年泰康保险养老社招入职统一测评(心理、认知、潜质)北森真题题库、高分攻略
  • 【系统分析师】第4章-基础知识:计算机网络与分布式系统(核心总结)
  • 从0开始学习语言模型--Day02-如何最大化利用硬件
  • 什么是装饰器?
  • 紧急救援!Ubuntu崩溃修复大赛
  • 三次贝塞尔曲线,二次贝塞尔曲线有什么区别
  • 通达信 玄学首板 抓首版指标
  • 11.OpenCV—联合QT环境配置
  • PoE供电异常如何排查?
  • leetcode 搜索插入位置 java
  • ArcGIS中英文切换
  • 62-STM32的ISP一键下载电路
  • 华为OD机试_2025 B卷_磁盘容量排序(Python,100分)(附详细解题思路)
  • 语言模型是怎么工作的?通俗版原理解读!
  • 第六十四节:基于EasyOCR的中英文文本识别与图像标注技术研究
  • 微信小程序 按钮点击事件
  • 概率期望DP
  • Luckfox Pico Pi RV1106学习<4>:RV1106的帧率问题