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博客

相关推荐
前端开发呀1 分钟前
成为开源项目的Contributor:从给uView-pro 贡献一次PR开始
前端·微信小程序
1024肥宅6 分钟前
JavaScript 数组原生方法手写实现
前端·javascript·ecmascript 6
rockmelodies12 分钟前
CVE-2025-55182:React Server Components 断点跟踪
前端·react.js·前端框架
草帽lufei17 分钟前
3大免费AI工具实战测评,用提示词“调教”出业务大屏
前端·ai编程·trae
汉堡大王952720 分钟前
JavaScript类型变形记:当代码开始“不正经”地转换身份
前端·javascript
Miss妤22 分钟前
Gemini写应用(二)
前端
用户930510658222423 分钟前
自造微前端
前端·javascript
之恒君24 分钟前
寄生组合继承 vs ES6 类继承 深度对比
前端·javascript
涔溪26 分钟前
整理vue3+ vite 开发经常会遇到的问题。
前端·vue.js·typescript
用户516816614584129 分钟前
script 标签的异步加载:async、defer、type="module" 详解
前端·javascript