[小程序]页面跳转

一、页面跳转

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})
  },
相关推荐
架构源启1 分钟前
Spring AI进阶系列(14)- 2026 可观测性最佳实践:从链路追踪到企业级 AI 治理落地
java·人工智能·spring
神奇的代码在哪里3 分钟前
【单机离线版】大学考试题库复习工具:前端离线Excel解析 + localStorage持久化 + Playwright
前端·html·ai编程·题库复习·刷题软件·大学考试
码上有光6 分钟前
c++: 继承(下)
android·java·c++·多继承·菱形继承·虚继承
JAVA9656 分钟前
JAVA面试-并发篇 02-synchronized 锁可以重入吗
java·面试
daols887 分钟前
vxe-table 实现数据分组统计与表尾合计
前端·javascript·vue.js·vxe-table
向日的葵0069 分钟前
Vue 函数定义、事件绑定与列表渲染精讲
前端·javascript·vue.js
RemainderTime11 分钟前
Spring Boot脚手架集成Sa-Token实现生产级RBAC权限管理
java·spring boot·后端·系统架构
神秘代码行者12 分钟前
pnpm zip命令详解
前端·npm·pnpm
韦胖漫谈IT13 分钟前
选语言不是站队,是选适合问题的工具
java·python·ai·rust·go·技术落地
lpd_lt16 分钟前
AI生成Spring Boot + Vue 3 + MySQL + MyBatis-Plus的项目实战
java·spring boot·vue·ai编程