搜尋
首頁微信小程式小程式開發微信小程式 頁面跳轉和資料傳遞

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

Jun 23, 2018 pm 03:33 PM
微信小程式頁面跳轉

這篇文章主要介紹了微信小程式頁面跳轉和資料傳遞實例詳解的相關資料,這裡附有實例程式碼幫助到家學習理解,需要的朋友可以參考下

#微信小程式頁面跳躍與資料傳遞

1.先導

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

1.wx.navigateTo(OBJECT);
2.wx.redirectTo(OBJECT);
3.wx.switchTab( OBJECT);
4.wx.navigateBack(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.頁面跳轉的具體操作

(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)

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

參數類型必填#urlString是需要跳轉的應用程式內非tabBar 的頁面的路徑,路徑後可以帶參數。參數與路徑間使用?分隔,參數鍵與參數值以=相連,不同參數以&分隔;如'path?key=value&key2=value2'successFunction否介面呼叫成功的回呼函數#failFunction否介面呼叫失敗的回呼函數complete#Function否介面呼叫結束的回調函數(呼叫成功、失敗都會執行)
範例程式碼:

wx.redirectTo({
 url: 'test?id=1'
})

##( 3)wx.switchTab(OBJECT)

跳到tabBar 頁面,並關閉其他所有非tabBar 頁面

OBJECT 參數說明:

#參數url#successfail#complete#介面呼叫結束的回呼函數(呼叫成功、失敗都會執行)
類型 必填 說明
#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: &#39;test?id=1&#39;//实际路径要写全
})

//test.js
Page({
 onLoad: function(option){
 console.log(option.id) 
 }
})

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

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

微信小程序实现实时圆形进度条的方法

微信小程序 监听手势滑动切换页面的实现

以上是微信小程式 頁面跳轉和資料傳遞的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中