都是双频无线路由,Vue路由怎么这么秀?

本文标识 : V00015

本文编辑 : Jack 风 编程工具 : Vscode 阅读时长 : 6分钟

什么是路由

路由分类

  • 对于普通的网站,所有的超链接都是URL地址,所有的URL地址都对应服务器上对应的资源;
  • 对于单页面应用程序来说,主要通过URL中的hash(#号)来实现不同页面之间的切换,同时,hash有一个特点:HTTP请求中不会包含hash相关的内容;所以,单页面程序中的页面跳转主要用hash实现; 在单页面应用程序中,这种通过hash改变来切换页面的方式,称作前端路由(区别于后端路由);

在 vue 中使用 vue-router

1.导入 vue-router 组件类库:

<!-- 1. 导入 vue-router 组件类库 -->    <script src="./lib/vue-router-2.7.0.js"></script>

2.使用 router-link 组件来导航

<!-- 2. 使用 router-link 组件来导航 -->  <router-link to="/login">登录</router-link>  <router-link to="/register">注册</router-link>

3.使用 router-view 组件来显示匹配到的组件

<!-- 3. 使用 router-view 组件来显示匹配到的组件 -->  <router-view></router-view>

4.创建使用`Vue.extend`创建组件

    // 4.1 使用 Vue.extend 来创建登录组件      var login = Vue.extend({        template: '<h1>登录组件</h1>'      });        // 4.2 使用 Vue.extend 来创建注册组件      var register = Vue.extend({        template: '<h1>注册组件</h1>'      });

5. 创建一个路由 router 实例,通过 routers 属性来定义路由匹配规则

// 5. 创建一个路由 router 实例,通过 routers 属性来定义路由匹配规则      var router = new VueRouter({        routes: [          { path: '/login', component: login },          { path: '/register', component: register }        ]      });

6. 使用 router 属性来使用路由规则

// 6. 创建 Vue 实例,得到 ViewModel      var vm = new Vue({        el: '#app',        router: router // 使用 router 属性来使用路由规则      });

· 设置路由高亮

· 设置路由切换动效

· 在路由规则中定义参数

1.在规则中定义参数:

{ path: '/register/:id', component: register }

2.通过 this.$route.params来获取路由中的参数:


var register = Vue.extend({ template: '<h1>注册组件 — {{this.$route.params.id}}</h1>' // 欢迎关注A2Data,感谢您的支持。 });

使用 `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>