1. 程式人生 > >vue router使用query和params傳參的使用

vue router使用query和params傳參的使用

跳轉 授權 data .org num 使用 組件 等等 navi

傳參是前端經常需要用的一個操作,很多場景都會需要用到上個頁面的參數,本文將會詳細介紹vue router 是如何進行傳參的,以及一些小細節問題。有需要的朋友可以做一下參考,希望可以幫到大家。

Vue router如何傳參

params、query是什麽?

params:/router1/:id ,/router1/123,/router1/789 ,這裏的id叫做params

query:/router1?id=123 ,/router1?id=456 ,這裏的id叫做query。

路由界面:

router.js:

路由設置這裏,當你使用params方法傳參的時候,要在路由後面加參數名,並且傳參的時候,參數名要跟路由後面設置的參數名對應。使用query方法,就沒有這種限制,直接在跳轉裏面用就可以。

技術分享圖片

註意:如果路由上面不寫參數,也是可以傳過去的,但不會在url上面顯示出你的參數,並且當你跳到別的頁面或者刷新頁面的時候參數會丟失(如下圖所示),那依賴這個參數的http請求或者其他操作就會失敗。

技術分享圖片

註意看上面的路由參數,id這個參數是我們有設置在路由上面的,id2我沒有設置在路由裏面,所以刷新之後id2就不見了,在項目中,我們總不可能要求用戶不能刷新吧。

組件1:

<template>
 <div class="app_page">
 <h1>從這個路由傳參到別的路由</h1>
 <router-link :to="{ name:‘router1‘,params: { id: status ,id2: status3},query: { queryId: status2 }}" >
  router-link跳轉router1
 </router-link>
 </div>
</template>
<script>
export default {
 name: ‘app_page‘,
 data () {
 return {
  status:110,
  status2:120,
  status3:119
 }
 },
}
</script>

  

編程式導航跳轉:

上面的router-link傳參,也可以使用router文檔裏面的編程式導航來跳轉傳參。

this.$router.push({ name:‘router1‘,params: { id: status ,id2: status3},query: { queryId: status2 }});
//編程跳轉寫在一個函數裏面,通過click等方法來觸發

  

這兩種傳參效果是一模一樣的,編程式導航,可以用來做判斷跳轉,比如是否授權,是否登錄,等等狀態,對此不太了解的小夥伴們,可以跳過這個編程式導航,以後再來看。

組件2:

<template>
 <div class="router1">
 <h1>接收參數的路由</h1>
 <h1> params.id:{{ $route.params }}</h1>
 <h1>query.status:{{ $route.query.queryId }}</h1>
 <keep-alive>
  <router-view></router-view>
 </keep-alive>
 </div>
</template>

  

傳參還是比較簡單的,按著上面組件的使用方法就可以成功傳過去了。

提示:獲取路由上面的參數,用的是$route,後面沒有r。

vue router使用query和params傳參的使用