vue3中的router和useRouter的区别

结论:从vue-router的官方文档中发现,useRouter需要在setup中使用,而router可以在任何组件中使用。 二者是等价的,适用场景不同。

问题:使用useRouter创建的实例,未能成功调用方法push()。会报错:Uncaught (in promise) TypeError: Cannot read properties of undefined (reading 'push')

javascript 复制代码
//错误场景:在js中调用useRouter
import { useRouter } from 'vue-router' 
const router = useRouter()

router.push({path:'/login'})

解决:改用router。

javascript 复制代码
import router from @/router'
router. push('/pathname')

原因:因为 useRouter只能在 setup中使用,如 以下场景:

router 适用面更广

参考:

vue3中的路由传参以及router和route的区别_useroute和userouter的区别_莫尔道嘎老范的博客-CSDN博客

vue3路由的两种引入方式useRouter和router进行页面跳转_userouter()_qq_26596795的博客-CSDN博客

相关推荐
小二·15 小时前
Next.js 15 全栈开发实战
开发语言·javascript·ecmascript
2501_9400417415 小时前
技术分享:高质量全栈开发提示词设计实践 —— 覆盖简单到复杂
前端·prompt
IT_陈寒15 小时前
Python的os.path.join居然能这么坑?
前端·人工智能·后端
艳阳天_.15 小时前
星瀚弹框页面实现
java·前端·python
杨若瑜16 小时前
本地开发环境慢?localhost的锅!
vue.js
EdgeOne边缘安全加速平台16 小时前
EdgeOne Web 防护×AI 升级:让 AI 既参与攻击识别,也参与误报纠错
前端·人工智能·腾讯云·edgeone
nuIl16 小时前
实现一个 Coding Agent(6):并行工具调用
前端·ai编程·cursor
Rain50916 小时前
2.1 Nest.js 项目初始化与模块化架构
开发语言·前端·javascript·后端·架构·数据分析·node.js
cjp56016 小时前
009. ASP.NET WEB API 用户关联esp32设备
前端·后端·asp.net
Insseals16 小时前
因斯特浮动模块快速接头✨五大核心优势
前端