• vue之vue-router加深印象.md


    定义

    单页面之间的跳转,建立并管理url与组件之间的映射关系

    使用

    <!--跳转组件 相当于a标签  to相当于href  -->
     <router-link to="/foo">Go to Foo</router-link>
    
    <!--路由出口 组件渲染在这里-->
     <router-view></router-view>
    

    模式

    history模式:不在url中显示#,而是和平常的html路径链接一样,底层是利用了HTML5 History新增的pushState()和replaceState()方法。需要后端支持,暂未用到。

    History模式就是通过pushState()方法来对浏览器的浏览记录进行修改,来达到不用请求后端来渲染的效果.

    hash模式:vue的默认路由模式,#代表url中的锚点,通过改变#后面的参数,不会重新加载界面,二是替换组件

    Hash模式就是通过改变#后面的值,实现浏览器渲染指定的组件.

    路由懒加载

    将组件拆分成代码块,防止打包过大

    const Foo = () => import('./Foo.vue')
    
    const router = new VueRouter({
      routes: [{ path: '/foo', component: Foo }]
    })
    

    路由守卫钩子函数

    全局守卫
    //前置守卫
    const router = new VueRouter({ ... })
    //to: Route: 即将要进入的目标 路由对象
    //from: Route: 当前导航正要离开的路由
    //next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数
    router.beforeEach((to, from, next) => {
      // ...
    })
    
    
    //后置守卫
    router.afterEach((to, from) => {
      // ...
    })
    
    路由独享的守卫
    const router = new VueRouter({
      routes: [
        {
          path: '/foo',
          component: Foo,
          beforeEnter: (to, from, next) => {
            // ...
          }
        }
      ]
    })
    
    组件内的守卫
    beforeRouteEnter(to, from, next) {
        // 在渲染该组件的对应路由被 confirm 前调用
        // 不!能!获取组件实例 `this`
        // 因为当守卫执行前,组件实例还没被创建
      },
      beforeRouteUpdate(to, from, next) {
        // 在当前路由改变,但是该组件被复用时调用
        // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
        // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
        // 可以访问组件实例 `this`
      },
      beforeRouteLeave(to, from, next) {
        // 导航离开该组件的对应路由时调用
        // 可以访问组件实例 `this`
      }
    

    组件传参

    //router.js
    const router = new VueRouter({
      routes: [
        { 
          path: '/user/:id', 
          component: User,
          props: true 
        },
    
        // 对于包含命名视图的路由,你必须分别为每个命名视图添加 `props` 选项:
        {
          path: '/user/:id',
          components: { default: User, sidebar: Sidebar },
          props: { default: true, sidebar: false }
        }
      ]
    })
    
    
    
    //user.vue
    //获取路由参数
    this.id =this.$route.params.id
    
    //组件跳转传参
     this.$router.push({
       path: '/user/10'
     });
    

    router,route,routers区别

    1、 router:一般指的就是路由实例.如$router。

    2、 route:指的就是路由对象.例如;$route指的就是当前路由对象。

    引用链接:

    vue官网: https://router.vuejs.org/zh/guide/#html

    掘金: https://juejin.cn/post/6844903665388486664#heading-27

  • 相关阅读:
    css3新特性
    线程间通信的三种方法
    硬件相关知识
    time.h
    ldr指令总结
    你不知道的100个小秘密
    ARM学习日记
    C中位域的使用
    《编程之美》第2刷勘误
    排序2
  • 原文地址:https://www.cnblogs.com/hanhaiyuntao/p/15186369.html
Copyright © 2020-2023  润新知