直接跳轉(zhuǎn):wx.navigateTo() 直接跳轉(zhuǎn):wx.navigateTo() 清空頁面棧再跳轉(zhuǎn):wx.reLaunch() 跳轉(zhuǎn)至 Tab Bar 頁面:wx.switchTab()
對于兩個或更多頁面的微信小程序而言,頁面之間的跳轉(zhuǎn)是在所難免的。
有關(guān)小程序頁面間跳轉(zhuǎn)的 API 函數(shù),微信一共為我們提供了 4 個(另外,還有返回上一級或多級的 wx.navigateBack
)。
下面,我將主要圍繞這四個 API 函數(shù),教你如何跳出頁面跳轉(zhuǎn)的大坑。
這四個 API 可接受的參數(shù)都是完全相同的,如下:
在小程序 JavaScript 邏輯代碼中的用法,也完全相同,具體語法為:
函數(shù)名({
url: "",
success: function () {},
fail: ...,
complete: ...
})
雖然它們有這么多的相同點,但它們絕對一點都不多余, 因為它們的用法完全各不相同。
wx.navigateTo()
wx.navigateTo()
用于保留當(dāng)前頁面、跳轉(zhuǎn)到應(yīng)用內(nèi)的某個頁面,使用 wx.navigateBack
可以返回到原頁面。
對于頁面不是特別多的小程序,通常推薦使用 wx.navigateTo
進(jìn)行跳轉(zhuǎn), 以便返回原頁面,以提高加載速度。當(dāng)頁面特別多時,則不推薦使用。
wx.redirectTo()
當(dāng)頁面過多時,被保留頁面會擠占微信分配給小程序的內(nèi)存,或是達(dá)到微信所限制的 5 層頁面棧。這時,我們應(yīng)該考慮選擇 wx.redirectTo
。
wx.redirectTo()
用于關(guān)閉當(dāng)前頁面,跳轉(zhuǎn)到應(yīng)用內(nèi)的某個頁面。這樣的跳轉(zhuǎn),可以避免跳轉(zhuǎn)前頁面占據(jù)運(yùn)行內(nèi)存,但返回時頁面需要重新加載,增加了返回頁面的顯示時間。
wx.reLaunch()
wx.reLaunch()
與 wx.redirectTo()
的用途基本相同, 只是 wx.reLaunch()
先關(guān)閉了內(nèi)存中所有保留的頁面,再跳轉(zhuǎn)到目標(biāo)頁面。
wx.switchTab()
對于跳轉(zhuǎn)到 tab bar 的頁面,最好選擇 wx.switchTab()
,它會先關(guān)閉所有非 tab bar 的頁面。
其次,也可以選擇 wx.reLaunch()
,它也能實現(xiàn)從非 tab bar 跳轉(zhuǎn)到 tab bar,或在 tab bar 間跳轉(zhuǎn),效果等同 wx.switchTab()
。
使用其他跳轉(zhuǎn) API 來跳轉(zhuǎn)到 tab bar,則會跳轉(zhuǎn)失敗。tab bar 如下所示(位于小程序底部):
wx.navigateBack()
wx.navigateBack()
用于關(guān)閉當(dāng)前頁面,并返回上一頁面或多級頁面。開發(fā)者可通過 getCurrentPages()
獲取當(dāng)前的頁面棧,決定需要返回幾層。
這個 API 需要填寫的參數(shù)只有 delta
,表示要返回的頁面數(shù)。若 delta
的取值大于現(xiàn)有可返回頁面數(shù)時,則返回到用戶進(jìn)入小程序的第一個頁面。
當(dāng)不填寫 delta
的值時,就默認(rèn)其為 1
(注意,默認(rèn)并非取 0
),即返回上一頁面。