首頁 web前端 uni-app uniapp中路由的使用技巧

uniapp中路由的使用技巧

Dec 18, 2023 pm 01:47 PM
uniapp 路由 技巧

uniapp中路由的使用技巧

uniapp中路由的使用技巧

一、概述​​
在uniapp開發中,路由是非常重要的一個方面,它可以實現頁面之間的跳轉和傳遞參數。本文將介紹uniapp中路由的使用技巧,並給出具體的程式碼範例。

二、uniapp路由的基本使用
在uniapp中,路由的基本使用可以透過uni.navigateTo、uni.redirectTo、uni.reLaunch、uni.switchTab等API來進行頁面跳躍。這些API的使用場景略有不同,視專案需求取決於專案需求。

  1. uni.navigateTo:用於開啟新頁面,並保留目前頁面。適用於普通的頁面跳轉。
    範例程式碼:

    uni.navigateTo({
     url: '/pages/detail/detail?id=1'
    });
    登入後複製
  2. uni.redirectTo:用於關閉目前頁面,並開啟新頁面。適用於不需要回到上一頁的頁面跳轉。
    範例程式碼:

    uni.redirectTo({
     url: '/pages/home/home'
    });
    登入後複製
  3. uni.reLaunch:關閉所有頁面,開啟到應用程式內的某個頁面。適用於從其他平台掃碼進入小程式的場景。
    範例程式碼:

    uni.reLaunch({
     url: '/pages/login/login'
    });
    登入後複製
  4. uni.switchTab:跳到tarBar頁面,並關閉其他所有非tarBar頁面。適用於底部導覽列頁面之間的跳轉。
    範例程式碼:

    uni.switchTab({
     url: '/pages/home/home'
    });
    登入後複製

三、uniapp路由參數的傳遞
在uniapp中,可以透過URL參數的方式來進行頁面之間的資料傳遞。

  1. 頁面之間傳遞參數
    在頁面A跳到頁面B時,可以透過URL參數來傳遞資料。在A頁面的跳躍程式碼中,透過拼接url的方式傳遞參數:

    uni.navigateTo({
     url: '/pages/detail/detail?id=' + id
    });
    登入後複製

#在B頁面中,可以透過uni.$route.query來取得參數值:

onLoad() {
    console.log(this.$route.query.id);
}
登入後複製
  1. 頁面返回時傳遞參數
    在uniapp中,可以透過uni.navigateBack方法傳回上一個頁面,並透過呼叫上一頁頁面的onBack方法傳遞參數。具體程式碼如下:
    在A頁面中,跳到B頁面時,傳遞參數,並註冊上一頁頁面的onBack方法:

    uni.navigateTo({
     url: '/pages/detail/detail?id=' + id + '&callback=onBack'
    });
    登入後複製

在B頁面中,取得參數值,並在頁面返回時呼叫上一頁頁面的onBack方法傳遞參數:

methods: {
    goBack() {
        uni.navigateBack({
            delta: 1,
            success: () => {
                uni.getOpenerEventChannel().emit(this.asr_notify);
            }
        });
    }
}
登入後複製

在A頁面中,註冊onBack方法並接收參數:

methods: {
    onBack(data) {
        console.log(data);
    }
}
登入後複製

四、uniapp路由攔截與權限控制
在開發過程中,有時需要對某些頁面進行權限控制,以阻止未登入使用者存取某些頁面。

在uniapp中,可以透過導航守衛來實現路由攔截和權限控制。具體程式碼如下:

  1. 建立全域路由攔截器,在main.js檔案中:

    // 全局路由拦截器
    router.beforeEach((to, from, next) => {
     const token = uni.getStorageSync('token');
     if (to.meta.requiresAuth && !token) { // 判断是否需要登录才能查看页面
         next('/pages/login/login');
     } else {
         next();
     }
    });
    登入後複製
  2. 在需要進行權限控制的頁面配置路由元資訊:

    export default {
     meta: {
         requiresAuth: true // 需要登录才能访问
     }
     // 省略其他代码...
    }
    登入後複製

透過上述操作,可實現對需要登入才能存取的頁面進行權限控制,未登入使用者將被攔截並跳到登入頁面。

總結:
本文介紹了uniapp中路由的基本使用方法、參數傳遞方式以及路由攔截與權限控制。透過合理的使用路由,可以實現頁面之間的跳轉和資料傳遞,提升應用程式的使用者體驗。

希望這篇文章對您對於uniapp路由的使用有所幫助。

以上是uniapp中路由的使用技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Win11小技巧分享:一招跳過微軟帳號登入 Win11小技巧分享:一招跳過微軟帳號登入 Mar 27, 2024 pm 02:57 PM

Win11小技巧分享:一招跳過微軟帳號登入Windows11是微軟最新推出的作業系統,具有全新的設計風格和許多實用的功能。然而,對於某些用戶來說,在每次啟動系統時都要登入微軟帳戶可能會感到有些煩擾。如果你是其中一員,不妨試試以下的技巧,讓你能夠跳過微軟帳號登錄,直接進入桌面介面。首先,我們需要在系統中建立一個本機帳戶,來取代微軟帳戶登入。這樣做的好處是

webstorm開發uniapp專案如何啟動預覽 webstorm開發uniapp專案如何啟動預覽 Apr 08, 2024 pm 06:42 PM

在 WebStorm 中啟動 UniApp 專案預覽的步驟:安裝 UniApp 開發工具外掛程式連接到裝置設定 WebSocket啟動預覽

uniapp和mui哪個好 uniapp和mui哪個好 Apr 06, 2024 am 05:18 AM

整體而言,需複雜原生功能時,uni-app 較好;需簡單或高度自訂介面時,MUI 較好。此外,uni-app 具備:1. Vue.js/JavaScript 支援;2. 豐富原生組件/API;3. 良好生態系。缺點是:1. 效能問題;2. 客製化介面困難。 MUI 具備:1. Material Design 支援;2. 高度彈性;3. 廣泛元件/主題庫。缺點是:1. CSS 依賴;2. 不提供原生元件;3. 生態系較小。

老手必備:C語言中*與&的技巧與注意事項 老手必備:C語言中*與&的技巧與注意事項 Apr 04, 2024 am 08:21 AM

C語言中,表示指針,儲存其他變數的位址;&表示位址運算符,傳回變數的記憶體位址。指針的使用技巧包括定義指針、解引用指針,需確保指針指向有效地址;地址運算符&的使用技巧包括取得變數地址,取得數組元素地址時返回數組第一元素地址。實戰案例說明了使用指標和位址運算子反轉字串。

uniapp用什麼開發工具 uniapp用什麼開發工具 Apr 06, 2024 am 04:27 AM

UniApp使用HBuilder X作為官方開發工具,該IDE整合了程式碼編輯器、偵錯器、模擬器和豐富的插件,為跨平台行動應用程式開發提供全面的支援。

新手製作表格有哪些技巧 新手製作表格有哪些技巧 Mar 21, 2024 am 09:11 AM

我們經常在excel中製作和編輯表格,但是作為一個剛剛接觸軟體的新手來講,如何使用excel製作表格,並沒有我們使用起來那麼輕鬆。下邊,我們針對新手,也就是初學者需要掌握的表格製作的一些步驟進行一些演練,希望對需要的人有些幫助。新手錶格範例樣板如下圖:我們看看如何完成! 1,新建excel文檔,有兩種方法。可以在【桌面】空白位置,點選滑鼠右鍵-【新建】-【xls】檔。也可以【開始】-【所有程式】-【MicrosoftOffice】-【MicrosoftExcel20**】2,雙擊我們新建的ex

uniapp有什麼缺點 uniapp有什麼缺點 Apr 06, 2024 am 04:06 AM

UniApp 作為跨平台開發框架擁有許多便利,但缺點也較為明顯:效能受限於混合開發模式,導致開啟速度、頁面渲染和互動回應較差。生態系統不完善,特定領域組件和庫較少,限制創意發揮和複雜功能實現。不同平台的相容性問題,易出現樣式差異和 API 支援不一致的情況。 WebView 的安全機制不同於原生應用,可能降低應用程式安全性。同時支援多個平台的應用程式發布更新需要多次編譯打包,增加開發和維護成本。

學uniapp需要哪些基礎 學uniapp需要哪些基礎 Apr 06, 2024 am 04:45 AM

uniapp開發需要以下基礎:前端技術(HTML、CSS、JavaScript)行動開發知識(iOS和Android平台)Node.js其他基礎(版本控制工具、IDE、行動開發模擬器或真機除錯經驗)

See all articles