安装路由
npm install vue-router -S
路由导航守卫
// to :是要去的哪个页面 路由相关的参数 (表示 将要访问的那个路由对象) // from :从哪个页面即将离开 (从哪个路由对象,跳转而来) // next :next 是一个函数,就相当于 Node 里面 express 中的 next 函数 (代表放行) // next() 表示放行 next('/login') 表示强制跳转到login页 // 注意: 这里的 router 就是 new VueRouter 得到的 路由对象 // 挂载路由导航守卫 router.beforeEach((to, from, next) => { // 如果用户输入的是login页面 直接放行 if (to.path === '/login') return next() // 查看客户端是否有token值 const tokenStr = window.sessionStorage.getItem('token') // 如果没有token 则直接跳转到登录页 if (!tokenStr) return next('/login') // 有token放行 next() }) // 把路由导航暴露出去 export default router
去掉地址栏的 # 号
const router = new VueRouter({ mode: 'history', // 这样就能去掉URL地址栏的 # 号 routes })
路由传参
使用<router-link to="">传递参数
父组件中: 使用 <router-link to="/需要跳转的路径/需要传递的参数"></router-link>
// to属性,表示 点击此链接,要跳转到哪个 hash 地址 // tag 属性 要渲染成什么标签 默认 是 a标签 tag可以转换成自己想要的标签 <router-link to="/跳转的地址/传递的参数" tag="li">首页</router-link>
子组件中,使用 props 来接收传递过来的参数
export default { props: ['传递的参数'] }
如果配置文件中没有开启 props 的话, 在子页面 可以使用 this.$route.params.传递的参数
路由配置文件(这是为接收页面开启的props)
{ path: '子路由地址/:传递的参数', component: 子路由文件,
props: true // 如果在组件中,想要拿到 path 中匹配的路由参数项, 可以为 路由规则 开启 props 传参 }
使用#router传递参数
this.$router.push({ path: '要跳转的地址', name: '要跳转的路径的 name,在 router 文件夹下的 index.js 文件内找', params: { // 需要传递的参数 键 值的格式 key: 'key', msgKey: this.msg } /*query: { // 需要传递的参数 键 值的格式 key: 'key', msgKey: this.msg }*/ })
接收
this.$route.params.键 this.$route.query.键
1.params
由于动态路由也是传递params的,所以在 this.$router.push() 方法中path不能和params一起使用,否则params将无效。需要用name来指定页面。
由于动态路由也是传递params的,所以在 this.$router.push() 方法中path不能和params一起使用,否则params将无效。需要用name来指定页面。
通过name和params传递参数
this.$router.push({ name: ‘index’, params: { username: “fatjack”, password: 123 }})
this.$router.push({ name: ‘index’, params: { username: “fatjack”, password: 123 }})
获取
this.$route.params.username
this.$route.params.username
<div>当前用户名: {{this.$route.params.uaername}} </div>
2.query
通过path和query传递参数
this.$router.push({path: ‘/index’, query: { username: “fatjack”, password: 123 }});
this.$router.push({path: ‘/index’, query: { username: “fatjack”, password: 123 }});
获取
this.$route.query.username
this.$route.query.username
之前的router-link是标签跳转;除了使用router-link是标签跳转之外,还可以使用Javascript来实现路由的跳转;
编程式导航
使用vue-router提供的JS API实现路由跳转的方式,叫做编程式导航;
编程式导航的用法
// 如果要跳转指定的 hash地址, 只能使用push方法
this.$router.push('路径的地址') 如果要跳转到指定hash地址,只能使用push方法
this.$router.go(n) n = -1 后退一步 n = 1 前进一步
this.$router.forward() 前进一步
this.$router.back() 后退一步
以上的记得都要注册在methods 里 的方法里
this.$route包含的信息
// fullpath 全地址 // path 路由地址 // params 路由的参数 // query 问号后查询的参数 // name 路由名称 // meta 路由元信息,标识路由是否需要全局守卫
路由基本样式
const routes = [ // 这个 routes 就是 路由 规则 的数组,里面要放很多的对应关系 // 路由规则的基本组成 { path: '/hash地址', component: 配置对象(要展示的组件) },在path中 ,带冒号的,是路由参数项 { path: '/', redirect: '/home' // 通过 redirect是属性,可以实现前端路由的重定向 如果访问的是 根路径 就会跳转到指定路径 },
{ path: '/home', component: Home, props: true // 开启路由传参 }, { path: '/about/:接收的参数', // :接收的参数 component: About, children: [ // children 定义子路由规则 { path: '/', component: '' } ] }] const router = new VueRouter({ routes, mode: 'history' // 区掉地址栏中的 # 号 }) export default router // 把路由暴露出去
vue-router路由