VUE路由router-link和router.push用法


兩者的區別

  使用router-link方式跳轉,會在頁面渲染的時候就加載對應的路由比起直接寫的方式的優點:不管是h5的history還是hash模式,切換的時候很方便;會默認阻止瀏覽器的默認事件;寫路徑的時候不用寫基路徑了。

  $router.push("/myroute")跳轉到對應的路徑,可在頁面中寫對應的點擊事件,然后執行對應的方法中寫跳轉,可在跳轉前再寫一些別的邏輯。

一、<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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM