[小程序]页面跳转

一、页面跳转

1.声明式导航

使用<navigate>组件实现(固定式),需要指定url 属性(跳转位置)和open-type属性(跳转方式)

①跳转tabBar页面

open-type 属性必须指定类型为switchTab

复制代码
<navigator url="/pages/index/index" open-type="switchTab">跳转index页</navigator>

②跳转非tabBar页面

open-type 属性必须指定位置navigate(可以缺省)

复制代码
<navigator url="/pages/logs/logs" open-type="navigate">跳转log页</navigator>

③后退导航

open-type 值为navigateBackdelta值为数字,表示返回的层级(默认为1)

复制代码
<navigator open-type="navigateBack" delta="1">返回上一级</navigator>

2.编程式导航

①跳转tabBar页面

调用API实现,使用**wx.switchTab(Object object)**方法来跳转,object对象中包含以下属性:

|----------|-----------|
| url | 跳转链接(必填项) |
| success | 成功时回调函数 |
| fail | 失败时回调函数 |
| complete | 结束时回调函数 |

复制代码
<button bindtap='goIndex'>跳转Index页</button>

goIndex(){
    wx.switchTab({
      url: '/pages/index/index',
    })
  },

②跳转非tabBar页面

调用wx.navigateTo实现,参数列表同上

复制代码
  goLogs(){
    wx.navigateTo({
      url: '/pages/logs/logs',
    })
  },

③返回导航

调用wx.navigateBack实现(不需要指定delta属性)

复制代码
  goBack(){
    wx.navigateBack()
  },

二、导航传参

1.声明式导航传参

类似于http中的GET指令,参数与路径之间使用 ? 进行分隔;参数键与参数之间以 = 相连;不同参数之间用 & 隔开。

复制代码
<navigator url="pages/show/show?name=Alice&age=18">跳转Show页</navigator>

2.编程式导航传参

基本和声明式一致,使用参数路径的方式传参

复制代码
  goShow(){
    wx.navigateTo({
      url: '/pages/show/show?name=Coco&age=22',
    })
  },

3.接收参数

传递给页面的参数可以在对应的onLoad参数中获取,如下:

复制代码
  onLoad(options) {
    this.setData({name:options.name})
    this.setData({age:options.age})
  },
相关推荐
寻星探路16 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
崔庆才丨静觅18 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
曹牧19 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
passerby606119 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了19 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅19 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅19 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
爬山算法19 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty72520 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai