小程序模板網(wǎng)

小程序頁面跳轉(zhuǎn)解析

發(fā)布時間:2018-01-03 09:54 所屬欄目:小程序開發(fā)教程

直接跳轉(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: ...
})

雖然它們有這么多的相同點,但它們絕對一點都不多余, 因為它們的用法完全各不相同。

直接跳轉(zhuǎn):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)存,但返回時頁面需要重新加載,增加了返回頁面的顯示時間。

清空頁面棧再跳轉(zhuǎn):wx.reLaunch()

wx.reLaunch() 與 wx.redirectTo() 的用途基本相同, 只是 wx.reLaunch() 先關(guān)閉了內(nèi)存中所有保留的頁面,再跳轉(zhuǎn)到目標(biāo)頁面。

跳轉(zhuǎn)至 Tab Bar 頁面: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 如下所示(位于小程序底部):

 

關(guān)閉頁面: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),即返回上一頁面。



易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://m.u-renovate.com/wxmini/doc/course/18366.html 復(fù)制鏈接 如需定制請聯(lián)系易優(yōu)客服咨詢:800182392 點擊咨詢
QQ在線咨詢
AI智能客服 ×