Vue Router4中params傳參失效和報(bào)錯(cuò)問(wèn)題的解決方法
問(wèn)題描述
在使用vue-router4中params 進(jìn)行路由組件之間傳參,跳轉(zhuǎn)頁(yè)面接收不了并出現(xiàn)如下錯(cuò)誤
如下是我的代碼
傳輸頁(yè)面
router.push({ name: "postBlog", params: { dialogVisible: true, data: data, }, });
接收頁(yè)面
import { useRouter } from "vue-router"; const route = useRouter(); const dialogVisible = ref(false) console.log(route.params)
原因分析:
點(diǎn)開(kāi)鏈接后發(fā)現(xiàn)了原因, 點(diǎn)擊查看更新日志
也就是說(shuō),從Vue Router的2022-8-22 這次更新后,我們使用上面的方式在新頁(yè)面無(wú)法獲取
解決方案:
vue也給我們提出了代替方案:
- 使用 query 的方式傳參
- 將參數(shù)放在 pinia 或 vuex倉(cāng)庫(kù)里
- 使用動(dòng)態(tài)路由匹配
- 傳遞 state,在新頁(yè)面使用 History API 接收參數(shù)
- 使用 meta 原信息方式傳遞 (此方式更適用于路由守衛(wèi))
使用動(dòng)態(tài)路由匹配
如果傳遞參數(shù)較少的情況下,可以嘗試使用下面這種方式,只要修改一下path定義部分就可以了:
// params 傳遞的參數(shù): { id: '1', name: 'ly', phone: 13246566476, age: 23 } { path: '/detail/:id/:name/:phone/:age', name: 'detail', component: () => import('@/views/detail/index.vue') }
查看頁(yè)面效果,控制臺(tái)警告也消失了:
注意,如果使用使用了這種動(dòng)態(tài)路由匹配方式, path: ‘/detail/:id/:name/:phone/:age’ ,中這三個(gè)參數(shù)你都必須傳遞,否則會(huì)報(bào)錯(cuò):
使用HistoryAPI方式傳遞和接收
在跳轉(zhuǎn)前的頁(yè)面使用 state 參數(shù):
<script setup> import { useRouter } from 'vue-router' const router = useRouter() const params = { id: '1', name: 'ly', phone: 13246566476, age: 23 } const toDetail = () => router.push({ name: 'detail', state: { params } }) </script> <template> <el-button type="danger" @click="toDetail">查看情頁(yè)</el-button> </template>
跳轉(zhuǎn)的后頁(yè)面接收:
<template> <div>{{ historyParams }}</div> </template> <script setup lang="ts"> const historyParams = history.state.params console.log('history.state', history.state) </script>
以上就是Vue Router4中params傳參失效和報(bào)錯(cuò)問(wèn)題的解決方法的詳細(xì)內(nèi)容,更多關(guān)于Vue params傳參失效和報(bào)錯(cuò)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue+mockjs模擬數(shù)據(jù)實(shí)現(xiàn)前后端分離開(kāi)發(fā)的實(shí)例代碼
本篇文章主要介紹了vue+mockjs模擬數(shù)據(jù)實(shí)現(xiàn)前后端分離開(kāi)發(fā)的實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08vue.js自定義組件實(shí)現(xiàn)v-model雙向數(shù)據(jù)綁定的示例代碼
這篇文章主要介紹了vue.js自定義組件實(shí)現(xiàn)v-model雙向數(shù)據(jù)綁定的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01Vue中使用?Aplayer?和?Metingjs?添加音樂(lè)插件的方式
這篇文章主要介紹了Vue中使用?Aplayer?和?Metingjs?添加音樂(lè)插件,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08