vue知识点-$route和$router

一、$route表示当前路由信息对象

  表示当前激活的路由的状态信息,包含了当前URL解析得到的信息,还有URL匹配到的路由记录

  路由信息对象:即$router会被注入每个组件中,可以利用它进行一些信息的获取

1)$route.path:

  字符串,对应当前路由的路径,总是解析为绝对路径:'/foo/bar'

2)$route.params

  一个key/value对象,包含了动态片段和全匹配片段

  如果没有路由参数,就是一个空对象

3)$route.query

  一个key/value对象,表示URL查询参数

  例如对于路径:/foo?user=1,则有$route.query.user=1

扫描二维码关注公众号,回复: 8387802 查看本文章

  如果没有查询参数就是一个空对象

4)$route.hash

  当前路由的hash值:不带#,如果没有hash值,则为空字符串。锚点

5)$route.fullPath

  完成解析后的URL,包含查询参数和hash的完整路径

6)$route.matched

  数组,包含当前匹配的路径中所包含的所有片段所对应的的配置参数对象

7)$route.name

  当前路径的名字

8)$route.meta

  路由元信息

二、$route的应用场景

  (1)在组件内,即this.$route

  (2)在$route观察者回调内 router.match(loaction)

  (3)导航守卫函数

    router.beforeEach((to,from,next) => {

      //to 和 from 都是路由信息对象

    })

    watch: {

      $route(to, from){

        //to 和 from 都是路由信息对象

      }

    }

三、$router对象

  全局的路由实例,是router构造方法的实例

  在vue实例内部,可以通过$router访问路由实例

  

  import Router from 'vue-router'  

  const routes = [

    {path:"/",name:首页,redirect:'/home'},

    {path:'/login',name:登录,component:Login},

    {path:'/home',component:Home}

  ] 

  const router = new Router {

    routes

  }

//全局注册路由,全局挂载路由实例

  Vue.use(Vuerouter)

四、//路由实例方法

  //字符串

  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方法和<route-link :to="...">是等价的

  注意:push方法的跳转会向history栈添加一个新的记录,当我们点击浏览器的返回按钮时可以看到之前的页面

  

五、路由实例方法go

  //页面路由跳转,前进或者后退

  this.$router.go(-1) //后退

  

  //页面实例方法replace

  push方法会向history栈添加一个新的记录,而replace方法是替换当前的页面

  一般使用replace方法来做404页面

  

转自:https://www.jianshu.com/p/fa0b5d919615

猜你喜欢

转载自www.cnblogs.com/jjbw/p/12129555.html