微信小程序开发实战(页面导航)

简介: 微信小程序开发实战(页面导航)

页面导航


1、什么是页面导航

页面导航指的是页面之间的相互跳转。

浏览器中实现页面导航的方式有如 👇:

① 《a》链接

② 类似 HTTP 重定向

window.location.replace(“url”);

③ 类似点击(a 标签)

window.location.href = “url”;

……

2、页面导航的两种方式


① 声明式导航

  1. 在页面上声明一个《navigator》导航组件
  2. 通过点击 《navigator》组件实现页面跳转

② 编程式导航

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

声明式导航


1. 导航到 tabBar 页面


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

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

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

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

注意❗:open-type为switchTab时必须有 底tabBar页面

如 👇

image.png

代码如 👇

<viewclass="home"><button><navigatorurl="/pages/page1/page1"open-type="switchTab">首页</navigator></button></view>

效果如 👇

1.gif

2. 导航到非 tabBar 页面


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

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

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

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

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

3. 后退导航


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

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

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

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


代码如 👇

<navigatoropen-type="navigateBack"delta="1">后退</navigator>

效果如 👇

2.gif

编程式导航


1. 导航到 tabBar 页面


调用 wx.switchTab(Object object) 方法,可以跳转到 tabBar 页面。

其中 Object 参数对象的属性列表如 👇

image.png

代码如 👇

//导航到tabbar页面programming(){
wx.switchTab({
url: '/pages/page2/page2',
  })
},

2. 导航到非 tabBar 页面


调用 wx.navigateTo(Object object) 方法,可以跳转到非 tabBar 的页面。

其中 Object 参数对象的属性列表 如 👇

image.png

代码如 👇

//导航到非tabbar页面feiProgramming(){
wx.navigateTo({
url: '/pages/page3/page3',
  })
},

3. 后退导航


调用 wx.navigateBack(Object object) 方法,可以返回上一页面或多级页面。

其中 Object 参数对象可选的属性列表如 👇

image.png

代码如 👇

//后退//非tab导航houtui(){
wx.navigateBack()
},

效果 如 👇

3.gif

导航传参


1、声明式导航传参


navigator 组件的 url 路径的后面可以携带参数 如 👇

  1. 参数与路径之间使用 ? 分隔
  2. 参数键与参数值用 = 相连
  3. 不同参数用 & 分隔

代码示例如 👇

<navigatorurl="/pages/page3/page3?name=小明&age=18"open-type="navigate">非tab页面</navigator>

2、编程式导航传参


调用 wx.navigateTo(Object object) 方法跳转页面时,也可以携带参数.

代码示例如 👇

//导航到非tabbar页面feiProgramming(){
wx.navigateTo({
url: '/pages/page3/page3?name=张三&age=18',
  })
},

3、在 onLoad 中接收导航参数


通过声明式导航传参或编程式导航传参所携带的参数,可以直接在 onLoad 事件中直接获取到.

代码示例如 👇

onLoad:function(options) {
this.setData({
query:options  })
},

效果 如 👇

4.gif

最后


image.png

下篇文章再见ヾ( ̄▽ ̄)ByeBye

image.png

相关文章
|
4月前
|
缓存 小程序 API
微信小程序页面导航与路由:实现多页面跳转与数据传递
本文深入探讨微信小程序的页面导航与路由机制,介绍多种页面跳转方式如`wx.navigateTo`、`wx.redirectTo`、`wx.switchTab`等,并讲解通过URL、全局变量和事件传递数据的方法。结合案例实现多页面跳转与数据传递,帮助开发者掌握这一重要技能。
|
8月前
|
小程序 前端开发 开发者
小程序的页面如何布局?
【10月更文挑战第16天】小程序的页面如何布局?
513 1
|
9月前
|
JSON 小程序 JavaScript
微信小程序页面事件,下拉刷新事件和上拉触底事件
这篇文章介绍了微信小程序中如何实现下拉刷新和上拉触底事件,包括开启下拉刷新、配置下拉刷新样式、监听下拉刷新事件,以及监听上拉触底事件和配置上拉触底的距离。
|
2月前
|
小程序 Java 关系型数据库
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。
|
3月前
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
1237 11
技术小白如何利用DeepSeek半小时开发微信小程序?
|
2月前
|
小程序 关系型数据库 Java
weixin168“返家乡”高校暑期社会实践微信小程序设计与开发ssm(文档+源码)_kaic
本文探讨高校暑期社会实践微信小程序的开发与应用,旨在通过信息化手段提升活动管理效率。借助微信小程序技术、SSM框架及MySQL数据库,实现信息共享、流程规范和操作便捷。系统涵盖需求分析、可行性研究、设计实现等环节,确保技术可行、操作简便且经济合理。最终,该小程序可优化活动发布、学生信息管理和心得交流等功能,降低管理成本并提高工作效率。
|
8月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
1912 7
|
8月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
1306 1
|
3月前
|
小程序 JavaScript 前端开发
微信小程序开发全流程:从注册到上线的完整指南
这篇文章详细记录了微信小程序的完整开发到最终上线的每一个步骤。适合对小程序开发感兴趣的个人开发者或希望了解完整流程的学习者,涵盖了云开发、事件绑定、生命周期管理、组件使用等关键内容。
1024 11
|
8月前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
1394 7

热门文章

最新文章