欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3.0?setup中使用vue-router問題

 更新時間:2022年10月19日 10:51:57   作者:ratel?  
這篇文章主要介紹了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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 加載 vue 遠程代碼的組件實例詳解

    加載 vue 遠程代碼的組件實例詳解

    vue-cli 作為 Vue 官方推薦的項目構建腳手架,它提供了開發(fā)過程中常用的,熱重載,構建,調試,單元測試,代碼檢測等功能。我們本次的異步遠端組件將基于 vue-cli 開發(fā)
    2017-11-11
  • Element el-table 表格使用詳解

    Element el-table 表格使用詳解

    我們的數(shù)據(jù)存儲到數(shù)據(jù)庫,不就是以表格的形式存在嗎,所以在界面上顯示、操作,使用表格來處理也是非常合理的,這篇文章給大家介紹Element el-table 表格使用方法,感興趣的朋友一起看看吧
    2024-03-03
  • vue中實現(xiàn)可編輯table及其中加入下拉選項

    vue中實現(xiàn)可編輯table及其中加入下拉選項

    這篇文章主要介紹了vue中實現(xiàn)可編輯table及其中加入下拉選項,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue2.0實現(xiàn)選項卡導航效果

    vue2.0實現(xiàn)選項卡導航效果

    這篇文章主要為大家詳細介紹了vue2.0實現(xiàn)選項卡導航效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • el-input限制輸入正整數(shù)的兩種實現(xiàn)方式

    el-input限制輸入正整數(shù)的兩種實現(xiàn)方式

    el-input框是Element UI庫中的一個輸入框組件,用于接收用戶的輸入,這篇文章主要介紹了el-input限制輸入正整數(shù),需要的朋友可以參考下
    2024-02-02
  • Vue中非父子組件通信的方法小結

    Vue中非父子組件通信的方法小結

    在Vue.js中,組件間的通信是構建復雜應用的關鍵,但當涉及到非父子關系的組件通信時,傳統(tǒng)的做法就顯得力不從心了,本文將深入探討幾種有效的非父子組件通信方法,并通過具體的代碼示例來幫助讀者理解和應用這些技術,需要的朋友可以參考下
    2024-09-09
  • vue如何實現(xiàn)簡易流程圖

    vue如何實現(xiàn)簡易流程圖

    這篇文章主要介紹了vue如何實現(xiàn)簡易流程圖問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue 實現(xiàn)小程序或商品秒殺倒計時

    vue 實現(xiàn)小程序或商品秒殺倒計時

    這篇文章主要介紹了vue 實現(xiàn)倒計時秒殺的組件,緊接著通過實例代碼給大家介紹小程序或者vue商品秒殺倒計時功能,需要的朋友可以參考下
    2019-04-04
  • vue動態(tài)添加路由后刷新頁面白屏問題及解決

    vue動態(tài)添加路由后刷新頁面白屏問題及解決

    這篇文章主要介紹了vue動態(tài)添加路由后刷新頁面白屏問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue日志之如何用select選中默認值

    vue日志之如何用select選中默認值

    這篇文章主要介紹了vue日志之如何select選中默認值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評論