vue3 setup 使用 beforeRouteEnter 組件內路由守衛

vue3 setup 使用 beforeRouteEnter 組件內路由守衛

setup 中只有onBeforeRouteLeaveonBeforeRouteUpdate兩個鉤子函數,
沒有beforeRouteEnter對應的鉤子函數,所以無法在setup中直接使用

<script setup>
onBeforeRouteLeave((to, from) => {// 在導航離開渲染該組件的對應路由時調用// 與 `beforeRouteUpdate` 一樣,它可以訪問組件實例 `this`// 鉤子沒有調用是因為 這個路由是直接輸入路由路徑進入的,為路由數組中的第一個,沒有上一級,所以這個鉤子沒有調用console.log('beforeRouteLeave');user.value = {id: '',name: ''};
});onBeforeRouteUpdate((to, from) => {// 在當前路由改變,但是該組件被復用時調用// 舉例來說,對于一個帶有動態參數的路徑 `/users/:id`,在 `/users/1` 和 `/users/2` 之間跳轉的時候,// 由于會渲染同樣的 `UserDetails` 組件,因此組件實例會被復用。而這個鉤子就會在這個情況下被調用。// 因為在這種情況發生的時候,組件已經掛載好了,導航守衛可以訪問組件實例 `this`console.log('beforeRouteUpdate');user.value = users.filter(user => user.id === to.params.id)[0];
});
</script>

解決方案:
使用選項式api 并使用defineExposedefineComponent中需要使用到的響應式數據暴露
就可以使用onBeforeRouteLeave

<script>
import {defineComponent} from "vue";export default defineComponent({beforeRouteEnter(to, from, next) {// 在渲染該組件的對應路由被驗證前調用// 不能獲取組件實例 `this` !// 因為當守衛執行時,組件實例還沒被創建!console.log('beforeRouteEnter');next(function (vm) {// console.log(vm)vm.user = vm.users.filter(user => user.id === to.params.id)[0];});}
});
</script><script setup>
import {reactive, ref} from "vue";
import {onBeforeRouteLeave, onBeforeRouteUpdate, useRouter} from "vue-router";const users = reactive([{id: '1',name: 'user1'},{id: '2',name: 'user2'},{id: '3',name: 'user3'},
]);const user = ref({id: '',name: ''
});
defineExpose({users, user});const router = useRouter();
const bru = () => {router.push({// path: '3',params: {id: '3'}});
}const back = () => {router.back();
}
onBeforeRouteLeave((to, from) => {// 在導航離開渲染該組件的對應路由時調用// 與 `beforeRouteUpdate` 一樣,它可以訪問組件實例 `this`// 鉤子沒有調用是因為 這個路由是直接輸入路由路徑進入的,為路由數組中的第一個,沒有上一級,所以這個鉤子沒有調用console.log('beforeRouteLeave');user.value = {id: '',name: ''};
});onBeforeRouteUpdate((to, from) => {// 在當前路由改變,但是該組件被復用時調用// 舉例來說,對于一個帶有動態參數的路徑 `/users/:id`,在 `/users/1` 和 `/users/2` 之間跳轉的時候,// 由于會渲染同樣的 `UserDetails` 組件,因此組件實例會被復用。而這個鉤子就會在這個情況下被調用。// 因為在這種情況發生的時候,組件已經掛載好了,導航守衛可以訪問組件實例 `this`console.log('beforeRouteUpdate');user.value = users.filter(user => user.id === to.params.id)[0];
});
</script>
<template><div><h1>User</h1><h1 v-text="user.name"></h1><button type="button" @click="bru">beforeRouteUpdate</button><button type="button" @click="back">beforeRouteLeave</button></div>
</template><style scoped></style>

vue vite ememet-plus

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/19745.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/19745.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/19745.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Android基礎-性能優化

在Android平臺上進行性能優化是確保應用程序高效、穩定且流暢運行的關鍵過程。以下將詳細闡述Android性能優化的各個方面&#xff0c;包括但不限于布局優化、繪制優化、內存管理、網絡優化、安裝包優化以及針對不同版本的Android系統進行適配等。 一、布局優化 布局優化的核心…

3D軟件開發的相關技術

3D開發涉及到廣泛的技術和工具&#xff0c;涵蓋了多個領域&#xff0c;包括計算機圖形學、編程、設計、物理模擬等。以下是3D開發中常用的技術和工具&#xff0c;掌握這些技術需要廣泛的知識和實踐&#xff0c;項目的成功依賴于對這些技術的有效整合和應用。北京木奇移動技術有…

音視頻開發14 FFmpeg 視頻 相關格式分析 -- H264 NALU格式分析

H264簡介-也叫做 AVC H.264&#xff0c;在MPEG的標準?是MPEG-4的?個組成部分–MPEG-4 Part 10&#xff0c;?叫Advanced Video Codec&#xff0c;因此常常稱為MPEG-4 AVC或直接叫AVC。 原始數據YUV,RGB為什么要壓縮-知道就行 在?視頻傳輸過程中&#xff0c;視頻?件的傳輸…

熱敏電阻的設計

熱敏電阻(NTC)的作用&#xff1a;抑制開機時的浪涌電流。防止開機瞬間產生的浪涌電流損壞后面的元件。 取值依據:根據對開機的脈沖電流&#xff08;浪涌電流&#xff09;小于多少A&#xff1f; 由,這個U是指最大輸入電壓&#xff0c;I為要求的浪涌電流。 NTC是負溫度系數的熱…

收銀系統源碼--商超水果生鮮店收銀硬件要怎么選擇?

新零售時代&#xff0c;越來越多的商家開始明白&#xff0c;除了要做好店鋪定位、店面裝潢和商品的設定&#xff0c;還要選購最適合店鋪運營需求的收銀機和硬件&#xff0c;好的收銀機和收銀系統可以幫助商家做好收支統計、庫存管理、人員配置。客戶服務等工作。現在的智能收銀…

MySQL 索引使用(二)

本篇繼續介紹有關索引的使用。 目錄 一、SQL提示 二、單列索引和聯合索引 三、覆蓋索引 四、前綴索引 五、索引的使用原則 一、SQL提示 我們在使用索引來進行查詢時&#xff0c;很有可能會出現一個字段中包含多個索引的情況&#xff0c;例如這里有一個name字段&#xff0c…

從零開始學習Slam-旋轉矩陣旋轉向量四元組(二)

本文參考&#xff1a;計算機視覺life 僅作筆記用 書接上回&#xff0c;上回不清不楚的介紹了旋轉矩陣&旋轉向量和四元組 現在回顧一下重點&#xff1a; 本著繞誰誰不變的變則 假設繞z軸旋轉θ&#xff0c;旋轉矩陣為&#xff1a; 再回顧一下旋轉向量的表示以及這個基本記不…

SpringCloud如何實現SSO單點登錄?

目錄 一、SpringCloud框架介紹 二、什么是SSO單點登錄 三、單點登錄的必要性 四、SpringCloud如何實現SSO單點登錄 一、SpringCloud框架介紹 Spring Cloud是一個基于Spring Boot的微服務架構開發工具集&#xff0c;它整合了多種微服務解決方案&#xff0c;如服務發現、配置…

SpringSecurity6從入門到實戰之Filter過濾器回顧

SpringSecurity6從入門到實戰之Filter過濾器回顧 如果沒有SpringSecurity這個框架,我們應該通過什么去實現客戶端向服務端發送請求時,先檢查用戶是否登錄,登錄了才能訪問.否則重定向到登錄頁面 流程圖如下 官方文檔&#xff1a;https://docs.spring.io/spring-security/referen…

Ubuntu (18.04) _Mysql (8.0.X)設置密碼強度

首先 查看是否有密碼強度插件&#xff1a; SHOW PLUGINS; 如果沒有&#xff0c;則安裝 install plugin validate_password soname validate_password.so; 再次查看,會看到密碼強度插件已開 其次 查看密碼強度具體配置 show variables like validate_password%; validate…

【C++】【VScode】常用快捷鍵

在Visual Studio Code (VSCode) 中&#xff0c;有幾個快捷鍵可以幫助你更高效地編寫C代碼&#xff0c;特別是與代碼提示、自動完成等功能相關的快捷鍵。這些功能大多數依賴于安裝和配置好的C/C擴展&#xff08;通常是由Microsoft提供的&#xff09;。以下是幾個有助于代碼提示和…

echart擴展插件詞云echarts-wordcloud

echart擴展插件詞云echarts-wordcloud 一、效果圖二、主要代碼 一、效果圖 二、主要代碼 // 安裝插件 npm i echarts-wordcloud -Simport * as echarts from echarts; import echarts-wordcloud; //下載插件echarts-wordcloud import wordcloudBg from /components/wordcloudB…

uniapp實現圖片上傳——支持APP、微信小程序

uniapp實現圖片、視頻上傳 文章目錄 uniapp實現圖片、視頻上傳效果圖組件templatejs 使用 相關文檔&#xff1a; 結合 uView 插件 uni.uploadFile 實現 u-upload uploadfile 效果圖 組件 簡單封裝&#xff0c;還有很多屬性…&#xff0c;自定義樣式等…根據個人所需調整 te…

Nginx在Docker中的應用:容器化部署與擴展

在當今的云計算和微服務時代&#xff0c;Docker容器技術因其輕量級、可移植性和可擴展性而受到廣泛關注。Nginx&#xff0c;作為一個高性能的HTTP和反向代理服務器&#xff0c;也在Docker中找到了其廣泛的應用場景。本文將探討Nginx在Docker中的容器化部署和擴展策略&#xff0…

16:00面試,16:08就出來了,問的問題有點變態。。。

從小廠出來&#xff0c;沒想到在另一家公司又寄了。 到這家公司開始上班&#xff0c;加班是每天必不可少的&#xff0c;看在錢給的比較多的份上&#xff0c;就不太計較了。沒想到8月一紙通知&#xff0c;所有人不準加班&#xff0c;加班費不僅沒有了&#xff0c;薪資還要降40%…

【C語言】常見的動態內存的錯誤

前言 在動態內存函數的使用過程中我們可能會遇到一些錯誤&#xff0c;這里將常見的錯誤進行總結。 對NULL解引用 請看以下代碼&#xff1a; 可以看到&#xff0c;這時我們的malloc開辟是失敗的&#xff0c;所以返回的是空指針NULL&#xff0c;而我們卻沒有進行檢查&#xff0…

推薦:4本易發表的優質SSCI期刊,含期刊官網!

01、Risk Management and Healthcare Policy 開源四區&#xff0c;國人發表占比25%&#xff0c;發表量前三的國家分別是中國、埃塞俄比亞和美國。 該期刊對國人友好&#xff0c;年度發文量400多&#xff0c;影響因子3.6。 主要刊發公共衛生相關的文章。 研究者可以圍繞居民…

【C++ C#】 C++ 和C# 的混合項目,C++ 文件中有多個 函數和變量 定義了未使用,會影響程序正常執速度嗎?

文章目錄 1 未使用的函數和變量 是否會影響速度分析1.1 C 未使用的函數和變量&#xff1a;1.2 C# 未使用的函數和變量&#xff1a; 2 影響程序執行速度的其他因素3 如何處理未使用的代碼 一個 C 和C# 的混合項目&#xff0c;C 文件中有多個 函數和變量 定義了未使用&#xff0c…

推薦系統三十六式學習筆記:01|你真的需要個性化推薦系統嗎?

目錄 什么是推薦系統你需要推薦系統嗎總結 什么是推薦系統 讓我們來換一個角度回答三個問題&#xff0c;從而重新定義什么是推薦系統: 1、它能做什么&#xff1f; 2、它需要什么&#xff1f; 3、它怎么做。 對于第一個問題“它能做什么”&#xff0c;我的回答是&#xff1a;推…

2020年CSP-J入門級第一輪初賽真題

一、選擇題 在內存儲器中每個存儲單元都被賦予一個唯一的序號&#xff0c;稱為&#xff08;&#xff09;。 A.地址 B. 序號 C. 下標 D. 編號 答案&#xff1a;A. 地址 在內存儲器中&#xff0c;每個存儲單元都有一個唯一的標識&#xff0c;用于區分和訪問不同的存儲單元。這個唯…