色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

如何處理vue router 路由傳參刷新頁(yè)面參數(shù)丟失

瀏覽:3日期:2022-09-29 18:50:28
目錄概述方法一:通過(guò) params 傳參方法二:通過(guò) query 傳參方法三:使用 props 配合組件路由解耦概述

常見(jiàn)場(chǎng)景:點(diǎn)擊列表的詳情,跳轉(zhuǎn)到詳情內(nèi)頁(yè),在內(nèi)頁(yè)根據(jù)傳遞的參數(shù)獲取詳情數(shù)據(jù)。

如何處理vue router 路由傳參刷新頁(yè)面參數(shù)丟失

路由傳參一般有如下幾種方式,下面主要介編程式導(dǎo)航 router.push 的傳參方式:

方法一:通過(guò) params 傳參

路由配置如下:

{ path: ’/detail/:id’, //若id后面加?代表這個(gè)參數(shù)是可選的 name: ’detail’, component: Detail }

通過(guò) $router.push 中 path 攜帶參數(shù)的方式

// 列表中的傳參goDetail(row) { this.$router.push({path: `/detail/${row.id}` })}// 詳情頁(yè)獲取參數(shù)this.$route.params.id

通過(guò) $router.push 的 params 傳參

// 列表頁(yè)傳參goDetail(row) { this.$router.push({name: ’detail’,params: { id: row.id} })}// 詳情頁(yè)獲取this.$route.params.id

注:這種方式的傳參,路徑用 name,路徑用 name,路徑用 name , 用 path 會(huì)獲取不到;如果在路由配置中沒(méi)有添加 /:id即 path: ’detail’,url 中不會(huì)顯示 id,在詳情頁(yè)還是可以拿到參數(shù) id,但刷新后參數(shù)丟失。

以上這兩種方式,傳遞的參數(shù) id 會(huì)在 url 后面顯示,如圖:

如何處理vue router 路由傳參刷新頁(yè)面參數(shù)丟失

傳遞的參數(shù)會(huì)暴露在網(wǎng)址中。

如果在路由中設(shè)置了params參數(shù) /:id,但是在跳轉(zhuǎn)的時(shí)候沒(méi)有傳遞參數(shù),會(huì)導(dǎo)致頁(yè)面沒(méi)有內(nèi)容或跳轉(zhuǎn)失敗,可在后面加 ?代表這個(gè)參數(shù)是可選的,即 /:id?

方法二:通過(guò) query 傳參

// 路由配置{ path: ’/detail’, name: ’detail’, component: Detail }// 列表頁(yè)goDetail(row) { this.$router.push({path: ’/detail’,query: { id: row.id} })}// 詳情頁(yè)this.$route.query.id

注:這種方式傳遞的參數(shù)會(huì)在地址欄的 url 后面顯示 ?id=?,類(lèi)似于 get 傳參;query 必須配合 path 來(lái)傳參。

傳遞的參數(shù)是對(duì)象或數(shù)組

還有一種情況就是,如果通過(guò) query 的方式傳遞對(duì)象或數(shù)組,在地址欄中會(huì)被強(qiáng)制轉(zhuǎn)換成 [object Object],刷新后也獲取不到對(duì)象值。

此時(shí)可以通過(guò) JSON.stringify() 方法將要傳遞的參數(shù)轉(zhuǎn)換為字符串傳遞,在詳情頁(yè)再通過(guò) JSON.parse() 轉(zhuǎn)換成對(duì)象。

let parObj = JSON.stringify(obj)this.$router.push({ path: ’/detail’, query: {’obj’: parObj }})// 詳情頁(yè)JSON.parse(this.$route.query.obj)

這個(gè)方法雖然可以傳遞對(duì)象,若數(shù)據(jù)少還好,數(shù)據(jù)多的話(huà)地址欄就很長(zhǎng)了

注意:在所有的子組件中獲取路由參數(shù)是 $route不是 $router

以上 params 和 query 傳參方式對(duì)比:

通過(guò) $router.push 的 params + name 傳參,若路由中沒(méi)有設(shè)置params參數(shù),參數(shù)不會(huì)拼接在路由后面,但是頁(yè)面刷新參數(shù)會(huì)丟失。 通過(guò) $router.push 中 path 攜帶參數(shù)或通過(guò) query 傳參,參數(shù)會(huì)拼接在地址后面,會(huì)暴露信息。方法三:使用 props 配合組件路由解耦

// 路由配置{ path: ’/detail/:id’, name: ’detail’, component: Detail, props: true // 如果props設(shè)置為true,$route.params將被設(shè)置為組件屬性}// 列表頁(yè)goDetail(row) { this.$router.push({path: ’/detail’,query: { id: row.id} })}// 詳情頁(yè)export default { props: {// 將路由中傳遞的參數(shù)id解耦到組件的props屬性上id: String }, mounted: {console.log(this.id) }}

此外,還可以通過(guò)把參數(shù)存在 sessionStorage 或 localStorage 中來(lái)解決頁(yè)面刷新參數(shù)丟失的問(wèn)題,具體結(jié)合實(shí)際項(xiàng)目即可。

以上就是如何處理vue router 路由傳參刷新頁(yè)面參數(shù)丟失的詳細(xì)內(nèi)容,更多關(guān)于vue的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 日本特级黄毛片毛片视频 | 欧美一级视 | 亚洲欧美另类自拍第一页 | 国产精品亚洲二线在线播放 | 欧美国产精品亚洲精品第一区 | 国产日韩在线观看视频 | 亚洲欧美中文在线观看4 | 国产一级毛片卡 | 欧美成人爽毛片在线视频 | 久久精品福利视频在线观看 | 国产亚洲自在精品久久 | 毛片网站免费在线观看 | 免费一极毛片 | 精品国产成人a区在线观看 精品国产成人a在线观看 | 国产三级国产精品国产普男人 | 国产精品高清免费网站 | 爽爽视频在线观看 | xxxxx日本59| 欧美精品国产一区二区三区 | 亚洲最大的视频网站 | 婷婷三级| 国产午夜毛片一区二区三区 | 成人a区| 欧美一区二区三区免费播放 | 又www又黄又爽啪啪网站 | 亚洲视频在线一区 | 欧美 日韩 国产 在线 | 日本乱理伦中文三区 | 九九久久久久午夜精选 | 一色屋精品亚洲香蕉网站 | 99久久伊人一区二区yy5o99 | 精品一区二区三区在线视频 | 99久久精品免费国产一区二区三区 | 免费观看a毛片一区二区不卡 | 亚洲一级高清在线中文字幕 | 无毒在线 | 国产精品自在自线亚洲 | 亚洲综合色吧 | 亚洲精品欧洲久久婷婷99 | 国产欧美综合一区二区 | 久久久久久久久久久福利观看 |