Vue-router

 Vue Router是Vue.js官方的路由管理器,严格来说,它是一款插件,但它又和Vue.js核心深度集成,Vue Router的版本依赖于Vue.js的版本,最新的vue-router 3.0 依赖于Vue.js 2.0及以上版本。

 

一  安装Vue-router

 

  1,简介

  Vue Router 有两种模式,分别是HTML5 History模式和hash模式。我们知道,Vue.js是主要用于构建单页面应用用户界面的渐进式框架,所以hash是Vue推荐的主力模式,如果你要使用History模式,需要配合后端进行一些单独的设置。

  Vue Router 提供的主要功能包括但不限于:

    嵌套路由和视图;

    基于模块化、组件化的路由配置;

    路由参数、查询;

    简单过渡效果。

    

  2,安装

   安装Vue Router也很简单,三种方式:script标签本地引入,CDN加速,模块化开发npm安装。

1 //标签本地引入
2 
3 
4 //vue-router依赖于vue.js,序偶一要先引入vue.js
1 //CDN加速
2 
3 
4 //同样需要先引入vue.js
1 //shell npm安装
2 npm install vue-router -d
3 //根据需要选择安装方式

  如果在模块化工程中使用它,必须要通过 Vue.use() 明确地安装路由功能:

1 import Vue from 'vue.js'
2 import VueRouter from 'vue-router.js'
3 
4 Vue.use('vueRouter')
5 //手动安装路由功能

   vue-router安装完成后,会在window上注册一个VueRouter属性,它是一个构造函数,稍后我们需要用它创建一个路由对象,并挂载到vue实例上。

 

二  路由规则

 

  1,基本模式

  使用Vue Router只需要简单的四步:

    a:定义路由组件;

1 const Foo = { template: '
foo
' } 2 const Bar = { template: '
bar
' } 3 //路由只需要模板对象,并不需要把该模板对象注册成真实的Vue组件,这一点需要特别注意

    b:定义路由规则;

 1 const routes = [
 2     { 
 3         path: '/foo',
 4         component: Foo 
 5     },
 6     { 
 7         path: '/bar',
 8         component: Bar
 9     }
10 ]
11 //路由规则是一个对象数组,每一个对象构建一条完整的路由规则,其中path和component是规则的必要属性,他们规定:在path指定的路径渲染component指定的组件。   

    c:创建路由实例;

1 const router = new VueRouter({
2     routes //ES6语法,相当于routes:routes
3 });
4 //为了能让路由最终运行起来,需要先创建一个router实例,稍后我们将选择合适的时机把它挂在到vue根实例上

    d:把路由实例挂载到vue根实例。

1 //方式一
2 const vm = new Vue({
3     el:'#app',
4     router
5 });
6 //方式二
7 const vm = new Vue({
8     router
9 }).$mount('#app');

  在JavaScript中设置好后还不够,为了在页面上有所表现,还需要在HTML页面中指定路径导航和组件渲染出口。

 1 <div id="app">
 2     <p>
 3         <router-link to="/foo" tag="button">Foorouter-link>
 4         <router-link to="/bar">Barrouter-link>
 5     p>
 6     <div>
 7         <router-view>douter-view>
 8     div>
 9 div>
10 
11 

  在完成以上这些操作后,页面上最终会有一个按钮和一个链接,点击他们将渲染对应的组件。

  

  2,路由重定向

  如果只是上面那样设置,会存在一个问题:首次进入页面时不会有任何组件被渲染。一般情况下,我们第一次进入页面,即根域名下时,希望展示一个默认组件,vue-router有两种方式可以实现。

 1 const routes = [
 2     {//重定向到一个已知组件
 3         path:'/',
 4         redirect:'/foo'
 5     },
 6     {//指定一个额外的页面,比如欢迎页
 7         path:'/',
 8         redirect:'/welcome'
 9     }
10 ]

  

  3,激活的样式

   为了让用户获得更好的体验,当用户点击某个时,我们可以给这个导航组件设置特别的样式,以提醒用户当前渲染的是什么,vue-router提供了两个css类来实现这一功能:router-link-active和router-link-exact-active。

1 router-link-active{
2     /*some code*/
3 }
4 router-link-exact-active{
5     /*some code*/
6 }

  另外你还可以通过给路由实例添加linkActiveClass和linkExactActiveClass两个属性来自定义这两个类名。

  这两个类的最终效果相同,但router-link-exact-active的优先级更高。

  

  4,路由过渡

  我们知道,是基本的动态组件,所以我们可以用  组件给它添加一些过渡效果。

1 
2   
3 

  上面的方式会给所有路由设置相同的过渡效果,如果你想给每个路由单独设置过渡效果,那么你需要在子组件内部单独使用,并为它设置name属性。

 1 const Foo = {
 2   template: `
 3     
 4       
...
5
6 ` 7 } 8 9 const Bar = { 10 template: ` 11 12
...
13
14 ` 15 }

 

三  路由操作

 

  1,路由传参

  VueRouter有两种方式向组件传递参数,分别是:$route.query和$route.params。下面通过示例来详细说明。

<div id="app">
    <router-link tag="button" to="/com1?name=ren&age=12">$route.queryrouter-link>
    <router-link tag="button" to="/com2/ren/12">$route.paramsrouter-link>
    <router-view><router-view>
div>

<script>
    var com1 = {
        template:"
{{$route.query.name}}:{{$route.query.age}}
", }; var com2 = { template:"
{{$route.params.name}}:{{$route.params.age}}
", }; const routerObj = new VueRouter({ routes:[ {path:'/com1',component:com1}, {path:'/com2/:age/:name',component:com2},] }); var vm = new Vue({ el:"#app", router:routerObj }); script>

  请注意两种方式使用时的差异:$route.query 通过url的查询参数(?问号后面的)传递数据,并且不需要修改路由规则(path属性)。$route.params 需要修改路由规则,通过定义变量(:冒号占位符)来获取数据,并且,路由规则中定义了多少个变量,触发路由(点击)时就必须传递多少个,否则路由将不能正常工作。

 

  2,路由嵌套

   VueRouter通过children属性实现路由嵌套。children属性是路由规则对象的另一个属性,和path,component属性同级。

 1 <div id="app">
 2     <router-link to="/com1">com1<router-link>
 3     <router-view>router-view>
 4 div>
 5 
 6 <template id="com1">
 7     <router-link to="/com1/login">loginrouter-link>
 8     <router-view>router-view>
 9 template>
10 <template id="login">
11     <p>loginp>
12 template>
 1 var routerObj = new VueRouter({
 2     routes:[
 3         {
 4             path:'/com1',
 5             component:com1,
 6             children:[
 7                 {path:'login',component:login}
 8             ]
 9         }
10     ]
11 });

  根路径下点击com1按钮将展示com1组件,在com1组件内有一个login按钮,点击该按钮将在com1组件内展示login组件。

  这里有一个注意点,children属性中的路由规则对象,其path属性不需要从根路径开始匹配(不需要从/斜线开始),当触发该路由时(/com1/login),它会自动从根路径开始,依次匹配/com1、/com1/path,最终成功渲染login组件。

  

  3,命名视图

  多数时候,当路由规则匹配到一个url路径时,我们需要展示的组件不止一个,这时候,我们就需要命名视图来帮忙了。

 1 <div id="app">
 2     <router-view>router-view>
 3     <router-view name="left">router-view>
 4     <router-view name="right">router-view>
 5 div>
 6 
 7 <script>
 8     var header = {template:'
header
'}; 9 var left = {template:'
left
'}; 10 var right = {template:'
right
'}; 11 12 const routerObj = new VueRouter({ 13 routes:[ 14 { 15 path:'/', 16 components:{default:header,left,right} 17 } 18 ] 19 }); 20 21 var vm = new Vue({ 22 el:'#app', 23 router:routerObj 24 }); 25 script>

  通过给添加name属性,并在路由规则对象中添加多个组件模板,即可以实现统一url地址匹配多个组件的需求了。

你可能感兴趣的:(Vue-router)