【微信小程序】页面导航

简介: 小程序 - 视图与逻辑页面导航1. 什么是页面导航2. 小程序中实现页面导航的两种方式页面导航 - 声明式导航1. 导航到 tabBar 页面2. 导航到非 tabBar 页面3. 后退导航页面导航 - 编程式导航1. 导航到 tabBar 页面2. 导航到非 tabBar 页面3. 后退导航

小程序 - 视图与逻辑


页面导航


1. 什么是页面导航


页面导航指的是 页面之间的相互跳转 。例如,浏览器中实现页面导航的方式有如下两种:


链接


② location.href


2. 小程序中实现页面导航的两种方式


① 声明式导航


在页面上声明一个  导航组件


通过点击  组件实现页面跳转


② 编程式导航


调用小程序的导航 API,实现页面的跳转


页面导航 - 声明式导航


1. 导航到 tabBar 页面


tabBar 页面 指的是被配置为 tabBar 的页面。


在使用  组件跳转到指定的 tabBar 页面时,需要指定 url 属性和 open-type 属性,其中:


url 表示要跳转的页面的地址,必须以 / 开头


open-type 表示跳转的方式,必须为 switchTab


示例代码如下:

<navigator url="/pages/message/message" open-type="switchTab">导航到消息页面</navigator>

2. 导航到非 tabBar 页面


非 tabBar 页面 指的是没有被配置为 tabBar 的页面。


在使用  组件跳转到普通的非 tabBar 页面时,则需要指定 url 属性和 open-type 属性,其中:


url 表示要跳转的页面的地址,必须以 / 开头


open-type 表示跳转的方式,必须为 navigate


示例代码如下:

<navigator url="/pages/info/info" open-type="navigate">导航到info页面</navigator>

注意:为了简便,在导航到非 tabBar 页面时,open-type="navigate" 属性可以省略。


3. 后退导航


如果要后退到上一页面或多级页面,则需要指定 open-type 属性和 delta 属性,其中:

open-type 的值必须是 navigateBack,表示要进行后退导航


delta 的值必须是数字,表示要后退的层级


示例代码如下:

<navigator open-type="navigateBack">后退</navigator>

注意:为了简便,如果只是后退到上一页面,则可以省略 delta 属性,因为其默认值就是 1。


页面导航 - 编程式导航


1. 导航到 tabBar 页面


调用 wx.switchTab( Object object ) 方法,可以跳转到 tabBar 页面。其中 Object 参数对象 的属性列表如下:


属性 类型 是否必选 说明


url string 是 需要跳转的 tabBar 页面的路径,路径后不能带参数


success function 否 接口调用成功的回调函数


fail function 否 接口调用失败的回调函数


complete function 否 接口调用结束的回调函数(调用成功、失败都会执行)

示例代码如下:

<button bindtap="gotoMessage">跳转到message页面</button>
 gotoMessage() {
    wx.switchTab({
      url: '/pages/message/message'
    })
  },

2. 导航到非 tabBar 页面


调用 wx.navigateTo( Object object ) 方法,可以跳转到非 tabBar 的页面。其中 Object 参数对象 的属性列表


如下:


属性 类型 是否必选 说明


url string 是 需要跳转的 tabBar 页面的路径,路径后不能带参数


success function 否 接口调用成功的回调函数


fail function 否 接口调用失败的回调函数


complete function 否 接口调用结束的回调函数(调用成功、失败都会执行)

示例代码如下:

<button bindtap="gotoInfo">跳转到info页面</button>
  gotoInfo() {
    wx.navigateTo({
      url: '/pages/info/info'
    })
  },

3. 后退导航


调用 wx.navigateBack( Object object ) 方法,可以返回上一页面或多级页面。其中 Object 参数对象 可选的


属性列表如下:


属性 类型 默认值 是否必选 说明


delta number 1 否 返回的页面数,如果 delta 大于现有页面数,则返回到首页

success function  否 接口调用成功的回调函数


fail function  否 接口调用失败的回调函数


complete function  否 接口调用结束的回调函数(调用成功、失败都会执行)

示例代码如下:

<button bindtap="goBack">后退</button>
  goBack() {
    wx.navigateBack({
      delta: 1
    })
  },
相关文章
|
9月前
|
缓存 小程序 API
微信小程序页面导航与路由:实现多页面跳转与数据传递
本文深入探讨微信小程序的页面导航与路由机制,介绍多种页面跳转方式如`wx.navigateTo`、`wx.redirectTo`、`wx.switchTab`等,并讲解通过URL、全局变量和事件传递数据的方法。结合案例实现多页面跳转与数据传递,帮助开发者掌握这一重要技能。
|
小程序 前端开发 开发者
小程序的页面如何布局?
【10月更文挑战第16天】小程序的页面如何布局?
777 1
|
小程序 JavaScript API
微信小程序开发学习之页面导航(声明式导航和编程式导航)
这篇文章介绍了微信小程序中页面导航的两种方式:声明式导航和编程式导航,包括如何导航到tabBar页面、非tabBar页面、后退导航,以及如何在导航过程中传递参数和获取传递的参数。
微信小程序开发学习之页面导航(声明式导航和编程式导航)
|
JSON 小程序 JavaScript
微信小程序页面事件,下拉刷新事件和上拉触底事件
这篇文章介绍了微信小程序中如何实现下拉刷新和上拉触底事件,包括开启下拉刷新、配置下拉刷新样式、监听下拉刷新事件,以及监听上拉触底事件和配置上拉触底的距离。
|
2月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
3月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
153 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
9月前
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
6月前
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
1340 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
5月前
|
监控 数据可视化 数据处理
微信养号脚本,全自动插件,AUTOJS开发版
这是一套自动化微信养号工具,包含主脚本`wechat_auto.js`与配置文件`config.json`。主脚本实现自动浏览朋友圈、随机阅读订阅号文章及搜索指定公众号三大功能,支持自定义滚动次数、阅读时长等参数。代码通过随机化操作间隔模拟真实用户行为,具备完善的错误处理和日志记录功能。配套UI模块提供可视化操作界面,可实时监控任务状态与运行日志,便于调整参数设置。控制器部分扩展了批量数据处理能力,如学生信息的增删改查操作,适用于多场景应用。下载地址:https://www.pan38.com/share.php?code=n6cPZ 提取码:8888(仅供学习参考)。
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
2876 7