微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

微信小程序 页面跳转和数据传递实例详解

微信小程序 页面跳转和数据传递

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可以返回到原页面

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

示例代码

rush:java;"> wx.navigateto({ url: 'test?id=1'//实际路径要写全 })
rush:java;"> //test.js Page({ onLoad: function(option){ console.log(option.query) } })

注意:为了不让用户在使用小程序时造成困扰,我们规定页面路径只能是五层,请尽量避免多层级的交互方式。

(2)wx.redirectTo(OBJECT)

关闭当前页面跳转到应用内的某个页面

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

示例代码

rush:js;"> wx.redirectTo({ url: 'test?id=1' })

(3)wx.switchTab(OBJECT)

跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面

OBJECT 参数说明:

参数 类型 必填 说明 跳转的 tabBar 页面的路径(需在 app.json 的 tabBar 字段定义的页面),路径后不能带参数调用成功的回调函数调用失败的回调函数调用结束的回调函数调用成功、失败都会执行)

示例代码

rush:js;"> { "tabBar": { "list": [{ "pagePath": "index","text": "首页" },{ "pagePath": "other","text": "其他" }] } }
rush:js;"> wx.switchTab({ url: '/index' })

(4)wx.navigateBack(OBJECT)

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

OBJECT 参数说明:

参数 类型 必填 说明 页面数,如果 delta 大于现有页面数,则返回到首页

示例代码

rush:js;"> // 注意:调用 navigateto 跳转时,调用方法页面会被加入堆栈,而 redirectTo 方法则不会。见下方示例代码

// 此处是A页面
wx.navigateto({
url: 'B?id=1'
})

rush:js;"> // 此处是B页面 wx.navigateto({ url: 'C?id=1' })
rush:js;"> // 在C页面内 navigateBack,将返回A页面 wx.navigateBack({ delta: 2 })

(5)使用标签实现页面跳转

navigator

页面链接

参数 类型 必填 说明 跳转链接页面重定向,对应 wx.redirectTo(将被废弃,推荐使用 open-type)eto、wx.redirectTo、wx.switchTab的功能效果

示例代码

rush:js;"> 跳转到新页面

3.页面的路由和生命周期

(1)页面的路由

小程序中所有页面的路由全部由框架进行管理,对于路由的触发方式以及页面生命周期函数如下:

路由方式 触发时机 路由后页面 路由前页面 小程序打开的第一个页面页面调用 API wx.navigateto 或使用组件页面重定向调用 API wx.redirectTo 或使用组件页面返回调用 API wx.navigateBack用户左上角返回按钮页面返回每个页面都会按顺序触发onUnload)调用 API wx.switchTab 或使用组件 或用户切换 Tab

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

当前页面 路由后页面 触发的生命周期(按顺序) nothing happend分享进入)分享进入)

4.参数传递

(1)通过路径传递参数

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

rush:js;"> ``` wx.navigateto({ url: 'test?id=1'//实际路径要写全 })
rush:js;"> //test.js Page({ onLoad: function(option){ console.log(option.id) } })

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

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。