微信小程式 頁面跳轉與資料傳遞實例詳解

高洛峰
發布: 2017-02-18 11:31:31
原創
1798 人瀏覽過

微信小程式 頁面跳轉和資料傳遞

1.先導

在Android中,我們Activity和Fragment都有堆疊的概念在裡面,微信小程式頁面也有堆疊的概念在裡面。微信小程式頁面跳躍有四種方式:

1.wx.navigateTo(OBJECT);
2.wx.redirectTo(OBJECT);
3.wx.switchTab(OBJECT);
4.w.navigate4.w.navigate4.w.navigate4.w.navigate4.w.navigate4.w.navigate4.w.navigate4.w.navigate4.w. OBJECT)
5.使用實現對應的跳轉功能;

分析:

  1. 其中navigateTo是將原來的頁面保存在頁面棧中,在跳入到下一個頁面的時候目標頁面也進棧,只有在這個情況下點選手機的返回按鈕才可以跳到上一個頁面;

  2. redirectTo和switchTab都是先清除棧中原來的頁面,然後目標頁面進棧,使用這兩種跳轉方式,都不能透過系統的返回鍵回到上一個頁面,而是直接退出小程式;

  3. redirectTo使用的時候一定要配合tabBar或是頁裡面可以再次跳轉按鈕,否則無法回到上一個頁面;

  4. switchTab跳轉的頁面必須是tabBar中宣告的頁面;

  5. tabBar中定義的欄位不能超過5個頁面,小程式的頁面堆疊層級也不能超過5層。

  6. navigateBack只能回到頁面堆疊中的指定頁面,一般和navigateTo配合使用。

  7. wx.navigateTo 和wx.redirectTo 不允許跳到tabbar 頁面,只能用wx.switchTab 跳到tabbar 頁面

2.頁面

(2.頁面

2.頁面

)wx.navigateTo(OBJECT)


保留目前頁面,跳到應用程式內的某個頁面,使用wx.navigateBack可以回到原始頁面。

參數型必填說明的頁面的路徑, 路徑後可以帶參數。參數與路徑之間使用?分隔,參數鍵與參數值以=相連,不同參數以&分隔;如'path?key=value&key2=value2'successFunctionsuccesssuccessFunctionsuccesssuccess的回呼函數failFunction否介面呼叫失敗的回呼函數complete並調用
Function
Function

範例程式碼:

wx.navigateTo({
 url: 'test?id=1'//实际路径要写全
})
登入後複製

//test.js
Page({
 onLoad: function(option){
 console.log(option.query) 
 }
})
登入後複製

注意:為了不讓使用者在使用小程式時造成困擾,我們規定頁數只能盡量避免五層互動路徑方式。

(2)wx.redirectTo(OBJECT)

關閉目前頁面,跳到應用程式內的某個頁面。

參數型必填說明套用內非tabBar 的頁面的路徑,路徑後可以帶參數。參數與路徑之間使用?分隔,參數鍵與參數值以=相連,不同參數以&分隔;如'path?key=value&key2=value2'successFunctionsuccessFunctionfailcomplete並調用
successFunction
successFunction
success的回呼函數
Function介面呼叫失敗的回呼函數

範例程式碼:

wx.redirectTo({
 url: 'test?id=1'
})
登入後複製

(3)wx.switchTab(OBJECT)

跳到


參數類型必填說明urlString是需要跳轉的tabBar 頁面的路徑(需在app.json 的tabBar 字段定義的頁面),路徑後不能帶參數successFunction否介面呼叫成功的回呼函數fail字的函數。 complete Function否介面呼叫結束的回呼函數(呼叫成功、失敗都會執行)

示例代码:

{
 "tabBar": {
 "list": [{
  "pagePath": "index",
  "text": "首页"
 },{
  "pagePath": "other",
  "text": "其他"
 }]
 }
}
登入後複製

wx.switchTab({
 url: '/index'
})
登入後複製

(4)wx.navigateBack(OBJECT)

关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages()) 获取当前的页面栈,决定需要返回几层。

OBJECT 参数说明:


参数类型必填说明
deltaNumber1返回的页面数,如果 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

页面链接。


参数类型必填说明
urlString
应用内的跳转链接
redirectBooleanfalse打开方式为页面重定向,对应 wx.redirectTo(将被废弃,推荐使用 open-type)
open-typeStringnavigate可选值 ‘navigate'、'redirect'、'switchTab',对应于wx.navigateTo、wx.redirectTo、wx.switchTab的功能
hover-classStringnavigator-hover指定点击时的样式类,当hover-class=”none”时,没有点击态效果
hover-start-timeNumber50按住后多久出现点击态,单位毫秒
hover-stay-timeNumber600手指松开后点击态保留时间,单位毫秒

示例代码:

<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,onShowonHide
页面重定向调用 API wx.redirectTo 或使用组件onLoad,onShowonUnload
页面返回调用 API wx.navigateBack 或用户按左上角返回按钮onShowonUnload(多层页面返回每个页面都会按顺序触发onUnload)
Tab 切换调用 API wx.switchTab 或使用组件 或用户切换 Tab各种情况请参考下表

Tab 切换对应的生命周期(以 A、B 页面为 Tabbar 页面,C 是从 A 页面打开的页面,D 页面是从 C 页面打开的页面为例):


当前页面路由后页面触发的生命周期(按顺序)
AANothing happend
ABA.onHide(), B.onLoad(), B.onShow()
AB(再次打开)A.onHide(), B.onShow()
CAC.onUnload(), A.onShow()
CBC.onUnload(), B.onLoad(), B.onShow()
DBD.onUnload(), C.onUnload(), B.onLoad(), B.onShow()
D(从分享进入)AD.onUnload(), A.onLoad(), A.onShow()
D(从分享进入)BD.onUnload(), B.onLoad(), B.onShow()

4.参数传递

(1)通过路径传递参数

通过路径传递参数在wx.navigateTo(OBJECT)、wx.redirectTo(OBJECT)和中使用方法相同
示例代码:以wx.navigateTo为代表

"
wx.navigateTo({
 url: &#39;test?id=1&#39;//实际路径要写全
})
登入後複製

//test.js
Page({
 onLoad: function(option){
 console.log(option.id) 
 }
})
登入後複製

参数与路径之间使用?分隔,参数键与参数值用=相连,不同参数用&分隔;

test?id=1 中id为参数键,1 为参数值

在目的页面中onLoad()方法中option对象即为参数对象,可以通过参数键来取出参数值

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

更多微信小程序 页面跳转和数据传递实例详解相关文章请关注PHP中文网!


來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!