vue3.0?setup中使用vue-router問題
vue3.0 setup中使用vue-router
在vue2.0中,我們通過this.$route可以獲取到當前的路由,然后通過this.$router來獲取到路由實例來進行路由跳轉,但是在setup中,我們是無法拿到this的,這也意味著我們不能像vue2.0那樣去使用vue-router, 此時就需要像下面這樣去使用
import { useRoute, useRouter } from 'vue-router'
?
export default {
? setup() {
? ? // 獲取當前路由
? ? const route = useRoute()
? ? // 獲取路由實例
? ? const router = useRouter()
? ? // 當前路由發(fā)生變化時,調用回調函數(shù)
? ? watch(() => route, () => {
? ? ? // 回調函數(shù)
? ? }, {
? ? ? immediate: true,
? ? ? deep: true
? ? })
? ??
? ? // 路由跳轉
? ? function goHome() {
? ? ? router.push({
? ? ? ? path: '/home'
? ? ? })
? ? }
? ??
? ? return {
? ? ? goHome()
? ? }
? }
}上面代碼使用watch來監(jiān)聽路由是否發(fā)生變化,除了watch之外,也可以使用vue-router提供的生命周期函數(shù)
import { onBeforeRouteUpdate, useRoute } from 'vue-router'
export default {
? setup() {
? ? onBeforeRouteUpdate(() => {
? ? ? // 當前路由發(fā)生變化時,調用回調函數(shù)
? ? })
? }
}除了onBeforeRouteUpdate之外 vue-router在路由離開的時候也提供了一個生命周期鉤子函數(shù)
onBeforeRouteLeave(() => {
? ?console.log('當前頁面路由離開的時候調用')
})vue-router4與vue3的setup使用

在 setup 中訪問路由和當前路由
因為我們在 setup 里面沒有訪問 this,所以我們不能再直接訪問 this.router 或 this.route。
使用useRouter和useRoute來代替
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 對象是一個響應式對象
所以它的任何屬性都可以被監(jiān)聽,但你應該避免監(jiān)聽整個 route 對象。在大多數(shù)情況下,你應該直接監(jiān)聽你期望改變的參數(shù)。
import { useRoute } from 'vue-router'
import { ref, watch } from 'vue'
export default {
setup() {
const route = useRoute()
const userData = ref()
// 當參數(shù)更改時獲取用戶信息
watch(
() => route.params.id,
async newId => {
userData.value = await fetchUser(newId)
}
)
},
}
請注意,在模板中我們仍然可以訪問 $router 和 $route,所以不需要在 setup 中返回 router 或 route。
導航守衛(wèi)
Vue Router 將更新和離開守衛(wèi)作為 組合式 API 函數(shù)公開
import { onBeforeRouteLeave, onBeforeRouteUpdate } from 'vue-router'
import { ref } from 'vue'
export default {
setup() {
// 與 beforeRouteLeave 相同,無法訪問 `this`
onBeforeRouteLeave((to, from) => {
const answer = window.confirm(
'Do you really want to leave? you have unsaved changes!'
)
// 取消導航并停留在同一頁面上
if (!answer) return false
})
const userData = ref()
// 與 beforeRouteUpdate 相同,無法訪問 `this`
onBeforeRouteUpdate(async (to, from) => {
//僅當 id 更改時才獲取用戶,例如僅 query 或 hash 值已更改
if (to.params.id !== from.params.id) {
userData.value = await fetchUser(to.params.id)
}
})
},
}
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
el-input限制輸入正整數(shù)的兩種實現(xiàn)方式
el-input框是Element UI庫中的一個輸入框組件,用于接收用戶的輸入,這篇文章主要介紹了el-input限制輸入正整數(shù),需要的朋友可以參考下2024-02-02

