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

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

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 参数说明:

参数类型必填说明
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中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP頁面跳躍函數詳解:header、location、redirect等函數的頁面跳躍技巧 PHP頁面跳躍函數詳解:header、location、redirect等函數的頁面跳躍技巧 Nov 18, 2023 pm 05:08 PM

PHP頁面跳轉函數詳解:header、location、redirect等函數的頁面跳轉技巧,需要具體程式碼範例引言:在開發Web網站或應用程式時,頁面之間的跳轉是一個不可或缺的功能。 PHP提供了多種方式來實現頁面跳轉,其中包括header函數、location函數以及一些第三方函式庫提供的跳轉函數,例如redirect。本文將詳細介紹這些函數的使用方

閒魚微信小程式正式上線 閒魚微信小程式正式上線 Feb 10, 2024 pm 10:39 PM

閒魚官方微信小程式悄悄上線,在小程式中可以發布閒置與買家/賣家私訊交流、查看個人資料及訂單、搜尋物品等,有用好奇閒魚微信小程式叫什麼,現在快來看一下。閒魚微信小程式叫什麼答案:閒魚,閒置交易二手買賣估價回收。 1、在小程式中可以發布閒置、與買家/賣家私訊交流、查看個人資料及訂單、搜尋指定物品等功能;2、在小程式的頁面中有首頁、附近、發閒置、訊息、我的5項功能;3、想要使用的話必要要開通微信支付才可以購買;

微信小程式實現圖片上傳功能 微信小程式實現圖片上傳功能 Nov 21, 2023 am 09:08 AM

微信小程式實現圖片上傳功能隨著行動網路的發展,微信小程式已經成為了人們生活中不可或缺的一部分。微信小程式不僅提供了豐富的應用場景,還支援開發者自訂功能,其中包括圖片上傳功能。本文將介紹如何在微信小程式中實作圖片上傳功能,並提供具體的程式碼範例。一、前期準備工作在開始編寫程式碼之前,我們需要先下載並安裝微信開發者工具,並註冊成為微信開發者。同時,也需要了解微信

實作微信小程式中的下拉式選單效果 實作微信小程式中的下拉式選單效果 Nov 21, 2023 pm 03:03 PM

實現微信小程式中的下拉式選單效果,需要具體程式碼範例隨著行動互聯網的普及,微信小程式成為了網路開發的重要一環,越來越多的人開始關注和使用微信小程式。微信小程式的開發相比傳統的APP開發更加簡單快捷,但也需要掌握一定的開發技巧。在微信小程式的開發中,下拉式選單是一個常見的UI元件,實現了更好的使用者操作體驗。本文將詳細介紹如何在微信小程式中實現下拉式選單效果,並提供具

實現微信小程式中的圖片濾鏡效果 實現微信小程式中的圖片濾鏡效果 Nov 21, 2023 pm 06:22 PM

實現微信小程式中的圖片濾鏡效果隨著社群媒體應用程式的流行,人們越來越喜歡在照片中應用濾鏡效果,以增強照片的藝術效果和吸引力。在微信小程式中也可以實現圖片濾鏡效果,為使用者提供更多有趣和創意的照片編輯功能。本文將介紹如何在微信小程式中實現圖片濾鏡效果,並提供具體的程式碼範例。首先,我們需要在微信小程式中使用canvas元件來載入和編輯圖片。 canvas元件可以在頁面

使用微信小程式實現輪播圖切換效果 使用微信小程式實現輪播圖切換效果 Nov 21, 2023 pm 05:59 PM

使用微信小程式實現輪播圖切換效果微信小程式是一種輕量級的應用程序,具有簡單、高效的開發和使用特點。在微信小程式中,實作輪播圖切換效果是常見的需求。本文將介紹如何使用微信小程式實現輪播圖切換效果,並給出具體的程式碼範例。首先,在微信小程式的頁面檔案中,新增一個輪播圖元件。例如,可以使用&lt;swiper&gt;標籤來實現輪播圖的切換效果。在該組件中,可以透過b

使用uniapp實現頁面跳轉動畫效果 使用uniapp實現頁面跳轉動畫效果 Nov 21, 2023 pm 02:15 PM

標題:使用uniapp實現頁面跳轉動畫效果近年來,行動應用程式的使用者介面設計已成為吸引使用者的重要因素之一。頁面跳轉動畫效果在提升使用者體驗和視覺化效果方面扮演著重要的角色。本文將介紹如何使用uniapp實現頁面跳轉動畫效果,並提供具體的程式碼範例。 uniapp是一個基於Vue.js開發的跨平台應用程式開發框架,可以透過一套程式碼編譯產生小程式、H5、App等多個平台的應用

實現微信小程式中的圖片旋轉效果 實現微信小程式中的圖片旋轉效果 Nov 21, 2023 am 08:26 AM

實現微信小程式中的圖片旋轉效果,需要具體程式碼範例微信小程式是一種輕量級的應用程序,為用戶提供了豐富的功能和良好的用戶體驗。在小程式中,開發者可以利用各種元件和API來實現各種效果。其中,圖片旋轉效果是一種常見的動畫效果,可以為小程式增添趣味性和視覺效果。在微信小程式中實作圖片旋轉效果,需要使用小程式提供的動畫API。以下是一個具體的程式碼範例,展示如何在小程

See all articles