WeChat 애플릿 페이지 점프 및 데이터 전송 예시에 대한 자세한 설명

高洛峰
풀어 주다: 2017-02-18 11:31:31
원래의
1795명이 탐색했습니다.

WeChat 애플릿 페이지 이동 및 데이터 전송

1. Pilot

Android에서는 Activity와 Fragment에 스택이 있습니다. 스택의 개념 그 안에 있고 WeChat 애플릿 페이지에도 스택 개념이 있습니다. WeChat 미니 프로그램 페이지로 이동하는 방법은 4가지가 있습니다:

1.wx.navigateTo(OBJECT)
2.wx.redirectTo(OBJECT); 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는 탭바 페이지로 점프하는 것을 허용하지 않으며 wx.switchTab만 탭바 페이지로 점프하는 데 사용할 수 있습니다.


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) 
 }
})
로그인 후 복사

참고: 미니 프로그램을 사용할 때 사용자에게 문제를 일으키지 않도록 페이지 경로는 5단계만 가능하다고 규정하고 있습니다. 다단계 상호작용은 피하세요.


(2) wx.redirectTo(OBJECT)

현재 페이지를 닫고 애플리케이션 내 페이지로 이동합니다.



参数类型必填说明
urlString需要跳转的应用内非 tabBar 的页面的路径,路径后可以带参数。参数与路径之间使用?分隔,参数键与参数值用=相连,不同参数用&分隔;如 ‘path?key=value&key2=value2'
successFunction接口调用成功的回调函数
failFunction接口调用失败的回调函数
completeFunction接口调用结束的回调函数(调用成功、失败都会执行)
샘플 코드:

wx.redirectTo({
 url: 'test?id=1'
})
로그인 후 복사

(3) wx .switchTab(OBJECT)

tabBar 페이지로 이동하고 tabBar가 아닌 다른 모든 페이지를 닫습니다.

OBJECT 매개변수 설명:


示例代码:

{
 "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 학습자의 빠른 성장을 도와주세요!