<script setup lang="ts">
const router = useRouter()
</script>
如果你只需要在模板内使用路由实例,可以使用 $router:
<template>
<button @click="$router.back()">
返回
</button>
</template>
如果你有一个 app/pages/ 目录,useRouter 的行为与 vue-router 提供的完全相同。
addRoute(): 向路由实例添加一个新路由。可以提供 parentName 将新路由添加为已有路由的子路由。removeRoute(): 通过路由名称移除一个已存在的路由。getRoutes(): 获取所有路由记录的完整列表。hasRoute(): 检查是否存在指定名称的路由。resolve(): 返回一个规范化后的路由定位对象,同时包含了 href 属性,href 会包含任何已有的基础路径。const router = useRouter()
router.addRoute({ name: 'home', path: '/home', component: Home })
router.removeRoute('home')
router.getRoutes()
router.hasRoute('home')
router.resolve({ name: 'home' })
back(): 如果可能,浏览历史记录返回,等同于 router.go(-1)。forward(): 如果可能,浏览历史记录前进,等同于 router.go(1)。go(): 在历史记录中前进或后退,不受 router.back() 和 router.forward() 中的层级限制。push(): 通过向历史栈推入一条新记录来编程式导航到新 URL。推荐使用 navigateTo 代替。replace(): 通过替换当前历史栈中的记录来编程式导航到新 URL。推荐使用 navigateTo 代替。const router = useRouter()
router.back()
router.forward()
router.go(3)
router.push({ path: '/home' })
router.replace({ hash: '#bio' })
useRouter 组合函数提供了 afterEach、beforeEach 和 beforeResolve 辅助方法,作为导航守卫。
但是,Nuxt 还有一个 路由中间件(route middleware) 的概念,它简化了导航守卫的实现并提供更好的开发体验。
如果你没有 app/pages/ 文件夹,那么 useRouter 将返回一个具有类似辅助方法的通用路由实例,但请注意,并非所有功能都被支持,或者行为可能不完全与 vue-router 一致。