美文网首页
vue 知识点整理——路由(vue-router)

vue 知识点整理——路由(vue-router)

作者: alokka | 来源:发表于2019-03-05 19:11 被阅读0次

    什么是路由

    1. 后端路由:对于普通的网站,所有的超链接都是URL地址,所有的URL地址都对应服务器上对应的资源;

    2. 前端路由:对于单页面应用程序来说,主要通过URL中的hash(#号)来实现不同页面之间的切换,同时,hash有一个特点:HTTP请求中不会包含hash相关的内容;所以,单页面程序中的页面跳转主要用hash实现;

    3. 在单页面应用程序中,这种通过hash改变来切换页面的方式,称作前端路由(区别于后端路由);

    在 vue 中使用 vue-router

    1. 导入 vue-router 组件类库:
    <!-- 1. 导入 vue-router 组件类库 -->
    import Router from 'vue-router'
    
    1. 使用 router-link 组件来导航
    <!-- 2. 使用 router-link 组件来导航 -->
    <router-link tag="div" to="/login">登录</router-link> // tag 可以通过配置 tag 属性生成别的标签
    <router-link tag="div" to="/register">注册</router-link>
    
    1. 使用 router-view 组件来显示匹配到的组件
    <!-- 3. 使用 router-view 组件来显示匹配到的组件 -->
    <router-view></router-view>
    
    1. 创建组件
      login.vue
      register.vue
    
    1. 创建一个路由 router 实例,通过 routers 属性来定义路由匹配规则
    // 5. 创建一个路由 router 实例,通过 routers 属性来定义路由匹配规则
        var router = new VueRouter({
          routes: [
            { 
              path: '/login', 
              component: login
            },
            { 
              path: '/register', 
              component: register 
            }
          ]
        });
    
    1. 使用 router 属性来使用路由规则
    // 6. 创建 Vue 实例,得到 ViewModel
        var vm = new Vue({
          el: '#app',
          router: router // 使用 router 属性来使用路由规则 可缩写为 router
        });
    

    动态路由匹配

    在路由规则中定义参数

    1. 在规则中定义参数:
    { path: '/register/:id', component: register }
    
    1. 通过 this.$route.params来获取路由中的参数:
    var register = Vue.extend({
          template: '<h1>注册组件 --- {{this.$route.params.id}}</h1>'
        });
    

    响应路由参数的变化

    提醒一下,当使用路由参数时,例如从 /user/foo 导航到 /user/bar,原来的组件实例会被复用。因为两个路由都渲染同个组件,比起销毁再创建,复用则显得更加高效。不过,这也意味着组件的生命周期钩子不会再被调用。

    复用组件时,想对路由参数的变化作出响应的话,你可以简单地 watch (监测变化) $route 对象:

    const User = {
      template: '...',
      watch: {
        '$route' (to, from) {
          // 对路由变化作出响应...
        }
      }
    }
    

    或者使用 2.2 中引入的 beforeRouteUpdate 导航守卫

    const User = {
      template: '...',
      beforeRouteUpdate (to, from, next) {
        // react to route changes...
        // don't forget to call next()
      }
    }
    

    捕获所有路由或 404 Not found 路由

    常规参数只会匹配被 / 分隔的 URL 片段中的字符。如果想匹配任意路径,我们可以使用通配符 (*):

    {
      // 会匹配所有路径
      path: '*'
    }
    {
      // 会匹配以 `/user-` 开头的任意路径
      path: '/user-*'
    }
    

    当使用通配符路由时,请确保路由的顺序是正确的,也就是说含有通配符的路由应该放在最后。路由 { path: '*' } 通常用于客户端 404 错误。如果你使用了History 模式,请确保正确配置你的服务器

    使用 children 属性实现路由嵌套

      <div id="app">
        <router-link to="/account">Account</router-link>
    
        <router-view></router-view>
      </div>
    
      <script>
        // 父路由中的组件
        const account = Vue.extend({
          template: `<div>
            这是account组件
            <router-link to="/account/login">login</router-link> | 
            <router-link to="/account/register">register</router-link>
            <router-view></router-view>
          </div>`
        });
    
        // 子路由中的 login 组件
        const login = Vue.extend({
          template: '<div>登录组件</div>'
        });
    
        // 子路由中的 register 组件
        const register = Vue.extend({
          template: '<div>注册组件</div>'
        });
    
        // 路由实例
        var router = new VueRouter({
          routes: [
            { path: '/', redirect: '/account/login' }, // 使用 redirect 实现路由重定向
            {
              path: '/account',
              component: account,
              children: [ // 通过 children 数组属性,来实现路由的嵌套
                { path: 'login', component: login }, // 注意,子路由的开头位置,不要加 / 路径符
                { path: 'register', component: register }
              ]
            }
          ]
        });
    
        // 创建 Vue 实例,得到 ViewModel
        var vm = new Vue({
          el: '#app',
          data: {},
          methods: {},
          components: {
            account
          },
          router: router
        });
      </script>
    

    命名视图实现经典布局

    1. 标签代码结构:
    <div id="app">
        <router-view></router-view>
        <div class="content">
          <router-view name="a"></router-view>
          <router-view name="b"></router-view>
        </div>
      </div>
    
    1. JS代码:
    <script>
        var header = Vue.component('header', {
          template: '<div class="header">header</div>'
        });
    
        var sidebar = Vue.component('sidebar', {
          template: '<div class="sidebar">sidebar</div>'
        });
    
        var mainbox = Vue.component('mainbox', {
          template: '<div class="mainbox">mainbox</div>'
        });
    
        // 创建路由对象
        var router = new VueRouter({
          routes: [
            {
              path: '/', components: {
                default: header,
                a: sidebar,
                b: mainbox
              }
            }
          ]
        });
    
        // 创建 Vue 实例,得到 ViewModel
        var vm = new Vue({
          el: '#app',
          data: {},
          methods: {},
          router
        });
      </script>
    
    1. CSS 样式:
      <style>
        .header {
          border: 1px solid red;
        }
    
        .content{
          display: flex;
        }
        .sidebar {
          flex: 2;
          border: 1px solid green;
          height: 500px;
        }
        .mainbox{
          flex: 8;
          border: 1px solid blue;
          height: 500px;
        }
      </style>
    

    相关文章

      网友评论

          本文标题:vue 知识点整理——路由(vue-router)

          本文链接:https://www.haomeiwen.com/subject/eiaiuqtx.html