vue3.0?setup中使用vue-router問(wèn)題
vue3.0 setup中使用vue-router
在vue2.0中,我們通過(guò)this.$route可以獲取到當(dāng)前的路由,然后通過(guò)this.$router來(lái)獲取到路由實(shí)例來(lái)進(jìn)行路由跳轉(zhuǎn),但是在setup中,我們是無(wú)法拿到this的,這也意味著我們不能像vue2.0那樣去使用vue-router, 此時(shí)就需要像下面這樣去使用
import { useRoute, useRouter } from 'vue-router' ? export default { ? setup() { ? ? // 獲取當(dāng)前路由 ? ? const route = useRoute() ? ? // 獲取路由實(shí)例 ? ? const router = useRouter() ? ? // 當(dāng)前路由發(fā)生變化時(shí),調(diào)用回調(diào)函數(shù) ? ? watch(() => route, () => { ? ? ? // 回調(diào)函數(shù) ? ? }, { ? ? ? immediate: true, ? ? ? deep: true ? ? }) ? ?? ? ? // 路由跳轉(zhuǎn) ? ? function goHome() { ? ? ? router.push({ ? ? ? ? path: '/home' ? ? ? }) ? ? } ? ?? ? ? return { ? ? ? goHome() ? ? } ? } }
上面代碼使用watch來(lái)監(jiān)聽(tīng)路由是否發(fā)生變化,除了watch之外,也可以使用vue-router提供的生命周期函數(shù)
import { onBeforeRouteUpdate, useRoute } from 'vue-router' export default { ? setup() { ? ? onBeforeRouteUpdate(() => { ? ? ? // 當(dāng)前路由發(fā)生變化時(shí),調(diào)用回調(diào)函數(shù) ? ? }) ? } }
除了onBeforeRouteUpdate之外 vue-router在路由離開(kāi)的時(shí)候也提供了一個(gè)生命周期鉤子函數(shù)
onBeforeRouteLeave(() => { ? ?console.log('當(dāng)前頁(yè)面路由離開(kāi)的時(shí)候調(diào)用') })
vue-router4與vue3的setup使用
在 setup 中訪(fǎng)問(wèn)路由和當(dāng)前路由
因?yàn)槲覀冊(cè)?setup 里面沒(méi)有訪(fǎng)問(wèn) this,所以我們不能再直接訪(fǎng)問(wèn) this.router 或 this.route。
使用useRouter和useRoute來(lái)代替
import{ useRouter, useRoute} from ‘vue-router' export default { setup() { const router = useRouter() const route = useRoute() function pushWithQuery(query) { router.push({ name: 'search', query: { ...route.query, }, }) } }, }
route 對(duì)象是一個(gè)響應(yīng)式對(duì)象
所以它的任何屬性都可以被監(jiān)聽(tīng),但你應(yīng)該避免監(jiān)聽(tīng)整個(gè) route 對(duì)象。在大多數(shù)情況下,你應(yīng)該直接監(jiān)聽(tīng)你期望改變的參數(shù)。
import { useRoute } from 'vue-router' import { ref, watch } from 'vue' export default { setup() { const route = useRoute() const userData = ref() // 當(dāng)參數(shù)更改時(shí)獲取用戶(hù)信息 watch( () => route.params.id, async newId => { userData.value = await fetchUser(newId) } ) }, }
請(qǐng)注意,在模板中我們仍然可以訪(fǎng)問(wèn) $router 和 $route,所以不需要在 setup 中返回 router 或 route。
導(dǎo)航守衛(wèi)
Vue Router 將更新和離開(kāi)守衛(wèi)作為 組合式 API 函數(shù)公開(kāi)
import { onBeforeRouteLeave, onBeforeRouteUpdate } from 'vue-router' import { ref } from 'vue' export default { setup() { // 與 beforeRouteLeave 相同,無(wú)法訪(fǎng)問(wèn) `this` onBeforeRouteLeave((to, from) => { const answer = window.confirm( 'Do you really want to leave? you have unsaved changes!' ) // 取消導(dǎo)航并停留在同一頁(yè)面上 if (!answer) return false }) const userData = ref() // 與 beforeRouteUpdate 相同,無(wú)法訪(fǎng)問(wèn) `this` onBeforeRouteUpdate(async (to, from) => { //僅當(dāng) id 更改時(shí)才獲取用戶(hù),例如僅 query 或 hash 值已更改 if (to.params.id !== from.params.id) { userData.value = await fetchUser(to.params.id) } }) }, }
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中實(shí)現(xiàn)可編輯table及其中加入下拉選項(xiàng)
這篇文章主要介紹了vue中實(shí)現(xiàn)可編輯table及其中加入下拉選項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08vue2.0實(shí)現(xiàn)選項(xiàng)卡導(dǎo)航效果
這篇文章主要為大家詳細(xì)介紹了vue2.0實(shí)現(xiàn)選項(xiàng)卡導(dǎo)航效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03el-input限制輸入正整數(shù)的兩種實(shí)現(xiàn)方式
el-input框是Element UI庫(kù)中的一個(gè)輸入框組件,用于接收用戶(hù)的輸入,這篇文章主要介紹了el-input限制輸入正整數(shù),需要的朋友可以參考下2024-02-02vue 實(shí)現(xiàn)小程序或商品秒殺倒計(jì)時(shí)
這篇文章主要介紹了vue 實(shí)現(xiàn)倒計(jì)時(shí)秒殺的組件,緊接著通過(guò)實(shí)例代碼給大家介紹小程序或者vue商品秒殺倒計(jì)時(shí)功能,需要的朋友可以參考下2019-04-04vue動(dòng)態(tài)添加路由后刷新頁(yè)面白屏問(wèn)題及解決
這篇文章主要介紹了vue動(dòng)態(tài)添加路由后刷新頁(yè)面白屏問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04