$route.name | 当前路径名字 |
$route.meta | 路由元信息 可以用在导航守卫查看要跳转的页面是否需要登录才能查看 |
$route.path | 字符串,对应当前路由的路径,总是解析为绝对路径,如"/foo/bar" |
$route.hash | 当前路由的hash值 (不带#) ,如果没有 hash 值,则为空字符串。锚点* |
$route.query | 一个 key/value 对象,表示 URL 查询参数。例如,对于路径 /foo?user=1,则有$route.query.user == 1,如果没有查询参数,则是个空对象 |
$route.params | 一个 key/value 对象,包含了 动态片段 和 全匹配片段,如果没有路由参数,就是一个空对象 |
$route.fullPath | 完成解析后的 URL,包含查询参数和hash的完整路径。 |
$route.matched | 数组,包含当前匹配的路径中所包含的所有片段所对应的配置参数对象。 |
1. $router.go()
$router.back 后退回到之前的 URL
页面路由跳转 $router.go(-1)为后退,$router.go(1)为前进 $router.forward()为前进
2. $router.push()
- 字符串this.$router.push('home')
- 对象this.$router.push({path:'home'})
- 命名的路由this.$router.push({name:'user',params:{userId:123}})
- 带查询参数,变成 /register?plan=123 this.$router.push({path:'register',query:{plan:'123'}})
- push方法其实和
注:push方法的跳转会向 history 栈添加一个新的记录,当我们点击浏览器的返回按钮时可以看到之前的页面。
3. $router.replace() 常用来做404页面
push方法会向 history 栈添加一个新的记录,而replace方法是替换当前的页面,
不会向 history 栈添加一个新的记录
this.$router.replace('/') 跳转到首页
原来的vue2路由是通过this.$route和this.$router来控制的。
现在vue3有所变化,useRoute相当于以前的this.$route,而useRouter相当于this.$router
import { useRouter } from 'vue-router'
export default {
setup() {
const userRouter = useRouter()
userRouter.push("/home")
}
}
push就是如上面的代码一样,就是在浏览器的历史记录中追加一个新的记录,你可以通过window.history看到这个记录。
而replace则是将当前的路由记录替换掉,替换后你如果回退,会发现上一个路由地址已经消失了
import { useRouter } from 'vue-router'
export default {
setup() {
const userRouter = useRouter()
userRouter.push({
path: '/about',
replace: true
})
}
}
import { useRouter } from 'vue-router'
export default {
setup() {
const userRouter = useRouter()
userRouter.replace({
path: '/about',
})
}
}
请注意params只与name搭配生效,name就是route配置时的name
import { useRouter } from 'vue-router'
export default {
setup() {
const userRouter = useRouter()
userRouter.push({
name: 'Home',
params: {
name: 'dx',
age: 18
}
})
}
}
通过useRoute来接收params参数
import { useRoute } from 'vue-router'
export default {
setup() {
const route = useRoute()
console.log(route.params)
}
}
import { useRouter } from 'vue-router'
export default {
setup() {
const userRouter = useRouter()
userRouter.push({
path: '/',
query: {
name: 'dx',
age: 18
}
})
}
}
通过useRoute来接收query参数
显示query在浏览器的url上,如果你直接通过字符串的方式去取,可能会涉及转码等问题,当然useRoute将这些都处理好了,所以还是推荐通过useRoute.query去取显式路由的参数
import { useRoute } from 'vue-router'
export default {
setup() {
const route = useRoute()
console.log(route.query)
}
}
传递和接收方式不同外
显式query会很明显的跟在新的url上,而隐式params不会
隐式params在刷新后可能会消失,我们可以在它存在的时候存如缓存中,如localstorage,而query不会
隐式params比显式query相对而言更安全,不会将参数直接暴露给用户
跟以前一样,我们在配置页面路由的时候就需要配置动态路由的名称,这里配置id
const routes: Array = [
{
path: '/about/:id',
name: 'About',
component: About
}
]
useRouter 传递动态参数id = 1 ,大多数时候动态参数都是简单数据类型,如果不是,你没必要用动态参数。
import { useRouter } from 'vue-router'
export default {
setup() {
const userRouter = useRouter()
userRouter.push({
path: '/about/1',
})
}
}
通过useRoute来接收动态参数的方式和params一样
import { useRoute } from 'vue-router'
export default {
setup() {
const route = useRoute()
console.log(route.params)
}
}