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

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

页面导航


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

相关文章
|
3天前
|
小程序 前端开发 生物认证
微信小程序如何将一个按钮放到页面的最底下?
微信小程序如何将一个按钮放到页面的最底下?
15 5
|
4天前
|
移动开发 小程序 JavaScript
uni-app开发微信小程序
本文详细介绍如何使用 uni-app 开发微信小程序,涵盖需求分析、架构思路及实施方案。主要功能包括用户登录、商品列表展示、商品详情、购物车及订单管理。技术栈采用 uni-app、uView UI 和 RESTful API。文章通过具体示例代码展示了从初始化项目、配置全局样式到实现各页面组件及 API 接口的全过程,并提供了完整的文件结构和配置文件示例。此外,还介绍了微信授权登录及后端接口模拟方法,确保项目的稳定性和安全性。通过本教程,读者可快速掌握使用 uni-app 开发微信小程序的方法。
19 3
|
13天前
|
小程序
Taro@3.x+Vue@3.x+TS开发微信小程序,设置转发分享
本文介绍了Taro中`useShareAppMessage`的使用方法,需在页面配置`enableShareAppMessage: true`并重新编译。
Taro@3.x+Vue@3.x+TS开发微信小程序,设置转发分享
|
13天前
|
小程序 数据安全/隐私保护
Taro@3.x+Vue@3.x+TS开发微信小程序,网络请求封装
在 `src/http` 目录下创建 `request.ts` 文件,并配置 Taro 的网络请求方法 `Taro.request`,支持多种 HTTP 方法并处理数据加密。
Taro@3.x+Vue@3.x+TS开发微信小程序,网络请求封装
|
13天前
|
小程序
Taro@3.x+Vue@3.x+TS开发微信小程序,上传文件
本文介绍如何在Taro项目中使用Nut UI的`&lt;nut-uploader/&gt;`组件实现图片上传功能,并通过示例代码展示了自定义上传逻辑的方法。
Taro@3.x+Vue@3.x+TS开发微信小程序,上传文件
|
13天前
|
小程序
Taro@3.x+Vue@3.x+TS开发微信小程序,根据系统主题展示不同样式(darkMode)
本文介绍如何在Taro项目中配置深色模式。通过在`src/app.config.ts`设置`darkmode`选项和在`theme.json`中定义主题变量,可以实现跟随系统主题的界面风格切换。
Taro@3.x+Vue@3.x+TS开发微信小程序,根据系统主题展示不同样式(darkMode)
|
12天前
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
30 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
|
12天前
|
小程序 前端开发 JavaScript
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
【避坑宝】是一款企业黑红名单吐槽小程序,旨在帮助打工人群体辨别企业优劣。该平台采用SpringBoot+MybatisPlus+uniapp+uview2等技术栈构建,具备丰富的注释与简洁的代码结构,非常适合实战练习与学习。通过小程序搜索“避坑宝”即可体验。
33 0
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
|
29天前
|
存储 小程序 JavaScript
|
29天前
|
小程序 前端开发 安全

热门文章

最新文章

下一篇
DDNS