Vue router重定向redirect如何傳值問題
Vue router重定向redirect如何傳值
配置 vue_router 時, 很經常就用到重定向(redirect)功能
例如:
沒登錄重定向到登錄頁面(導航衛(wèi)士攔截也是高效的登錄檢查方法)
index, home, house 重定向到首頁等
重定向 redirect 可接受的值
字符串
字符串作為 path 傳入, 相當于 { path: redirect }
{ ... redirect: "/assets/assetsIndex", ... } // 相當于 { ... redirect: { path: '/assets/assetsIndex' }, ... }
對象
先判斷有沒有 name
有 name
發(fā)起跳轉處提供的 name, query, hash, params 會往下傳
如果 redirect 也提供了這些屬性則用 redirect 提供的往下傳
redirect: { name: 'assetsIndex', params: { id: 'redirect' }, } // redirect 提供了 params, 目標組件可以收到該 params 數據 // redirect 沒有提供, 目標組件收到發(fā)起跳轉處的數據(發(fā)起跳轉是有數據的話)
沒有 name, 就找 path
計算后的 path 和 query, hash 會往下傳
如果 redirect 也提供了這些屬性則用 redirect 提供的往下傳
redirect: { path: 'assetsIndex', query: { id: 'redirect' }, }
方法
方法必須 return 一個字符串
return 的內容最終作為 path 往下傳
所以提供的 params 將無效
redirect: function (to) { return 'assetsIndex' }
這些不需要傳參的情況, 直接設置為目標地址的字符串就可以
{ path: "/assets", component: layout, redirect: "/assets/assetsIndex", }
如果你遇到的需求需要傳值的話, 可以參考下面的方法
query 帶參跳轉
query 直接帶參就可以了, 缺點是地址中會暴露參數
// 發(fā)起跳轉 this.$router.push({ name: 'assets', query: { val: 'val值' } }) /* or */ this.$router.push({ path: '/assets', query: { id: '編程式_id' } }) /* or */ this.$router.push("/assets?id=編程式_id") // 重定向 { path: "/assets", name: "assets", redirect: "/assetsHome", } // 目標路由 { path: "/assetsHome", component: assetsHome, }, // 目標組件中取值 this.$route.query
params 帶參跳轉
params 帶參相對麻煩, 因為"如果提供了 path,params 會被忽略"在 redirect 中也是成立的
所以我們可以知道, 不可以用 path 來設置路由
而 params 帶參的好處當然就是可以在地址隱藏參數了
// 發(fā)起跳轉 this.$router.push({ name: 'assets', params: { id: '編程式_id' } }) // 重定向 { path: "/assets", name: "assets", redirect: { name: 'assetsHome' }, } // 目標路由 { path: "/assetsHome", name: "assetsHome", component: assetsHome, } // 目標組件中取值 this.$route.params
動態(tài)路徑帶參跳轉
本來是不想寫這個方法的, 因為筆者本來就很討厭動態(tài)路徑帶參, 覺得那個方法局限性太大, 加一個參數很麻煩, 還要順序要求
為了不要被讀者吐槽我懶(敲代碼本來就是為了偷懶嘛), 還是稍微寫一下
// 發(fā)起跳轉 this.$router.push({ path: '/assets/編程式_id' }) // 重定向 { path: "/assets/:id", name: "assets", redirect: { name: 'assetsHome' }, } // 目標路由 { path: "/assetsHome/:id", name: "assetsHome", component: assetsHome, } // 目標組件中取值 this.$route.params
[題外話] 重定向和別名的區(qū)別
重定向是進入 a, 然后自動跳轉到 b
a 和 b 都是真實的路由地址, 這個過程經過兩地址, 只是 a 不會被記錄
別名是進入 a, 實際上是進入 b
a 不是真實的路由地址, 這個過程自始至終都只是在 b 地址
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
vue中 process.env與process.VUE_CLI_SERVICE詳解
這篇文章主要介紹了vue中process.env與process.VUE_CLI_SERVICE的相關資料,本文結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05vue.js組件vue-waterfall-easy實現瀑布流效果
這篇文章主要為大家詳細介紹了vue.js實現瀑布流之vue-waterfall-easy的相關資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08