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

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

高洛峰
高洛峰原創
2017-02-18 11:31:311819瀏覽

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

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並調用
success Function
success Function
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 参数说明:


参数 类型 必填 说明
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)使用0e1e9be57d3815196e4c83d329f1e05f标签实现页面跳转

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)和0e1e9be57d3815196e4c83d329f1e05f中使用方法相同
示例代码:以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中文网!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn