這篇文章主要介紹了微信小程式頁面跳轉和資料傳遞實例詳解的相關資料,這裡附有實例程式碼幫助到家學習理解,需要的朋友可以參考下
#微信小程式頁面跳躍與資料傳遞
1.先導
在Android中,我們Activity和Fragment都有堆疊的概念在裡面,微信小程式頁面也有堆疊的概念在裡面。微信小程式頁面跳轉有四種方式:
1.wx.navigateTo(OBJECT);
2.wx.redirectTo(OBJECT);
3.wx.switchTab( OBJECT);
4.wx.navigateBack(OBJECT)
5. 使用實作對應的跳轉功能;
分析:
其中navigateTo是將原來的頁面保存在頁面棧中,在跳入到下一個頁面的時候目標頁面也進棧,只有在這個情況下點擊手機的返回按鈕才可以跳到上一個頁面;
#redirectTo和switchTab都是先清除堆疊中原來的頁面,然後目標頁面進棧,使用這兩種跳躍方式,都不能透過系統的返回鍵回到上一個頁面,而是直接退出小程式;
redirectTo使用的時候一定要配合tabBar或是頁裡面可以再跳轉按鈕,否則無法回到上一個頁面;
-
switchTab跳轉的頁面必須是tabBar中宣告的頁面;
#tabBar中定義的欄位不能超過5個頁面,小程式的頁面堆疊層次也不能超過5層。
navigateBack只能回到頁面堆疊中的指定頁面,一般和navigateTo搭配使用。
wx.navigateTo 和wx.redirectTo 不允許跳到tabbar 頁面,只能用wx.switchTab 跳到tabbar 頁面
#2.頁面跳轉的具體操作
(1)wx.navigateTo(OBJECT)
#保留目前頁面,跳轉到應用程式內的某個頁面,使用wx.navigateBack可以回到原始頁面。
參數 | 類型 | 必填 | |
---|---|---|---|
#url | String | 是 | 需要跳轉的應用程式內非tabBar 的頁面的路徑, 路徑後可以帶參數。參數與路徑間使用?分隔,參數鍵與參數值以=相連,不同參數以&分隔;如'path?key=value&key2=value2' |
success | Function | 否 | 介面呼叫成功的回呼函數 |
#fail | Function | 否 | 介面呼叫失敗的回呼函數 |
complete | #Function | 否 | 介面呼叫結束的回調函數(呼叫成功、失敗都會執行) |
範例程式碼:
wx.navigateTo({ url: 'test?id=1'//实际路径要写全 })
##
//test.js Page({ onLoad: function(option){ console.log(option.query) } })注意:為了不讓使用者在使用小程式時造成困擾,我們規定頁面路徑只能是五層,請盡量避免多層級的互動方式。
(2)wx.redirectTo(OBJECT)
關閉目前頁面,跳到應用程式內的某個頁面。類型 | 必填 | ||
---|---|---|---|
String | 是 | 需要跳轉的應用程式內非tabBar 的頁面的路徑,路徑後可以帶參數。參數與路徑間使用?分隔,參數鍵與參數值以=相連,不同參數以&分隔;如'path?key=value&key2=value2' | |
Function | 否 | 介面呼叫成功的回呼函數 | |
Function | 否 | 介面呼叫失敗的回呼函數 | |
#Function | 否 | 介面呼叫結束的回調函數(呼叫成功、失敗都會執行) |
wx.redirectTo({ url: 'test?id=1' })##( 3)wx.switchTab(OBJECT)
跳到tabBar 頁面,並關閉其他所有非tabBar 頁面
OBJECT 參數說明:
類型 | 必填 | 說明 | |
---|---|---|---|
#String | 是 | 需要跳轉的tabBar 頁面的路徑(需在app.json 的tabBar 欄位定義的頁面),路徑後不能帶參數 | |
Function | #否 | #介面呼叫成功的回呼函數 | |
Function | 否 | 介面呼叫失敗的回呼函數 | |
Function | #介面呼叫結束的回呼函數(呼叫成功、失敗都會執行) |
示例代码:
{ "tabBar": { "list": [{ "pagePath": "index", "text": "首页" },{ "pagePath": "other", "text": "其他" }] } }
wx.switchTab({ url: '/index' })
(4)wx.navigateBack(OBJECT)
关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages()) 获取当前的页面栈,决定需要返回几层。
OBJECT 参数说明:
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
delta | Number | 1 | 返回的页面数,如果 delta 大于现有页面数,则返回到首页。 |
示例代码:
// 注意:调用 navigateTo 跳转时,调用该方法的页面会被加入堆栈,而 redirectTo 方法则不会。见下方示例代码 // 此处是A页面 wx.navigateTo({ url: 'B?id=1' })
// 此处是B页面 wx.navigateTo({ url: 'C?id=1' })
// 在C页面内 navigateBack,将返回A页面 wx.navigateBack({ delta: 2 })
(5)使用
navigator
页面链接。
参数 | 类型 | 必填 | 说明 |
---|---|---|---|
url | String | 应用内的跳转链接 | |
redirect | Boolean | false | 打开方式为页面重定向,对应 wx.redirectTo(将被废弃,推荐使用 open-type) |
open-type | String | navigate | 可选值 ‘navigate'、'redirect'、'switchTab',对应于wx.navigateTo、wx.redirectTo、wx.switchTab的功能 |
hover-class | String | navigator-hover | 指定点击时的样式类,当hover-class=”none”时,没有点击态效果 |
hover-start-time | Number | 50 | 按住后多久出现点击态,单位毫秒 |
hover-stay-time | Number | 600 | 手指松开后点击态保留时间,单位毫秒 |
示例代码:
<navigator url="navigate?title=navigate" hover-class="navigator-hover">跳转到新页面</navigator> <navigator url="redirect?title=redirect" open-type="redirect" hover-class="other-navigator-hover">在当前页打开</navigator> <navigator url="index" open-type="switchTab" hover-class="other-navigator-hover">切换 Tab</navigator>
3.页面的路由和生命周期
(1)页面的路由
在小程序中所有页面的路由全部由框架进行管理,对于路由的触发方式以及页面生命周期函数如下:
路由方式 | 触发时机 | 路由后页面 | 路由前页面 |
---|---|---|---|
初始化 | 小程序打开的第一个页面 | onLoad,onShow | |
打开新页面 | 调用 API wx.navigateTo 或使用组件 | onLoad,onShow | onHide |
页面重定向 | 调用 API wx.redirectTo 或使用组件 | onLoad,onShow | onUnload |
页面返回 | 调用 API wx.navigateBack 或用户按左上角返回按钮 | onShow | onUnload(多层页面返回每个页面都会按顺序触发onUnload) |
Tab 切换 | 调用 API wx.switchTab 或使用组件 或用户切换 Tab | 各种情况请参考下表 |
Tab 切换对应的生命周期(以 A、B 页面为 Tabbar 页面,C 是从 A 页面打开的页面,D 页面是从 C 页面打开的页面为例):
当前页面 | 路由后页面 | 触发的生命周期(按顺序) |
---|---|---|
A | A | Nothing happend |
A | B | A.onHide(), B.onLoad(), B.onShow() |
A | B(再次打开) | A.onHide(), B.onShow() |
C | A | C.onUnload(), A.onShow() |
C | B | C.onUnload(), B.onLoad(), B.onShow() |
D | B | D.onUnload(), C.onUnload(), B.onLoad(), B.onShow() |
D(从分享进入) | A | D.onUnload(), A.onLoad(), A.onShow() |
D(从分享进入) | B | D.onUnload(), B.onLoad(), B.onShow() |
4.参数传递
(1)通过路径传递参数
通过路径传递参数在wx.navigateTo(OBJECT)、wx.redirectTo(OBJECT)和
示例代码:以wx.navigateTo为代表
" wx.navigateTo({ url: 'test?id=1'//实际路径要写全 })
//test.js Page({ onLoad: function(option){ console.log(option.id) } })
参数与路径之间使用?分隔,参数键与参数值用=相连,不同参数用&分隔;
test?id=1 中id为参数键,1 为参数值
在目的页面中onLoad()方法中option对象即为参数对象,可以通过参数键来取出参数值
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
以上是微信小程式 頁面跳轉和資料傳遞的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver CS6
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。