直接跳轉(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() 用于保留當前頁面、跳轉(zhuǎn)到應(yīng)用內(nèi)的某個頁面,使用 wx.navigateBack 可以返回到原頁面。
對于頁面不是特別多的小程序,通常推薦使用 wx.navigateTo 進行跳轉(zhuǎn), 以便返回原頁面,以提高加載速度。當頁面特別多時,則不推薦使用。
wx.redirectTo()
當頁面過多時,被保留頁面會擠占微信分配給小程序的內(nèi)存,或是達到微信所限制的 5 層頁面棧。這時,我們應(yīng)該考慮選擇 wx.redirectTo。
wx.redirectTo() 用于關(guān)閉當前頁面,跳轉(zhuǎn)到應(yīng)用內(nèi)的某個頁面。這樣的跳轉(zhuǎn),可以避免跳轉(zhuǎn)前頁面占據(jù)運行內(nèi)存,但返回時頁面需要重新加載,增加了返回頁面的顯示時間。
wx.reLaunch()
wx.reLaunch() 與 wx.redirectTo() 的用途基本相同, 只是 wx.reLaunch() 先關(guān)閉了內(nèi)存中所有保留的頁面,再跳轉(zhuǎn)到目標頁面。
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)閉當前頁面,并返回上一頁面或多級頁面。開發(fā)者可通過 getCurrentPages() 獲取當前的頁面棧,決定需要返回幾層。
這個 API 需要填寫的參數(shù)只有 delta,表示要返回的頁面數(shù)。若 delta 的取值大于現(xiàn)有可返回頁面數(shù)時,則返回到用戶進入小程序的第一個頁面。
當不填寫 delta 的值時,就默認其為 1(注意,默認并非取 0),即返回上一頁面。