Vue-詳解設定路由導航的兩種方法:router-link和router.push
阿新 • • 發佈:2018-11-24
轉自:http://www.cnblogs.com/superlizhao/p/8527317.html
一、<router-link :to="...">
to裡的值可以是一個字串路徑,或者一個描述地址的物件。例如:
// 字串 <router-link to="apple"> to apple</router-link> // 物件 <router-link :to="{path:'apple'}"> to apple</router-link> // 命名路由 <router-link :to="{name: 'applename'}"> to apple</router-link> //直接路由帶查詢引數query,位址列變成 /apple?color=red <router-link :to="{path: 'apple', query: {color: 'red' }}"> to apple</router-link> // 命名路由帶查詢引數query,位址列變成/apple?color=red <router-link :to="{name: 'applename', query: {color: 'red' }}"> to apple</router-link> //直接路由帶路由引數params,params 不生效,如果提供了 path,params 會被忽略<router-link :to="{path: 'apple', params: { color: 'red' }}"> to apple</router-link> // 命名路由帶路由引數params,位址列是/apple/red <router-link :to="{name: 'applename', params: { color: 'red' }}"> to apple</router-link>
二、router.push(...)方法
同樣的規則也適用於router.push(...)方法。
// 字串 router.push('apple')// 物件 router.push({path:'apple'}) // 命名路由 router.push({name: 'applename'}) //直接路由帶查詢引數query,位址列變成 /apple?color=red router.push({path: 'apple', query: {color: 'red' }}) // 命名路由帶查詢引數query,位址列變成/apple?color=red router.push({name: 'applename', query: {color: 'red' }}) //直接路由帶路由引數params,params 不生效,如果提供了 path,params 會被忽略 router.push({path:'applename', params:{ color: 'red' }}) // 命名路由帶路由引數params,位址列是/apple/red router.push({name:'applename', params:{ color: 'red' }})
三、注意點
1、關於帶引數的路由總結如下:
無論是直接路由“path" 還是命名路由“name”,帶查詢引數query,位址列會變成“/url?查詢引數名:查詢引數值“;
直接路由“path" 帶路由引數params params 不生效;
命名路由“name" 帶路由引數params 位址列保持是“/url/路由引數值”;
2、設定路由map裡的path值:
帶路由引數params時,路由map裡的path應該寫成: path:'/apple/:color' ;
帶查詢引數query時,路由map裡的path應該寫成: path:'/apple' ;
3、獲取引數方法:
在元件中: {{$route.params.color}}
在js裡: this.$route.params.color