浅谈uniapp页面跳转的解决方案
作者:唯有灬努力 发布时间:2023-08-23 01:45:51
正常的页面跳转的api大家应该都清楚,但是涉及到多页面来回跳转以及返回到导航页的时候就需要一些技巧来进行处理,之前找了挺多文章也没有很详细的介绍,本文就详细说说页面跳转的那些事。
1.uniapp常用跳转API
API | 作用 |
---|---|
uni.navigateTo | 保留当前页面,跳转到应用内的某个页面,使用uni.navigateBack 可以返回到原页面。 |
uni.redirectTo | 关闭当前页面,跳转到应用内的某个页面。 |
uni.reLaunch | 关闭所有页面,打开到应用内的某个页面。 |
uni.switchTab | 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面。 |
uni.navigateBack | 关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages() 获取当前的页面栈,决定需要返回几层。 |
2.微信小程序页面跳转API
API | 作用 |
---|---|
wx.navigateTo | 保留当前页面,跳转到应用内的某个页面。 |
wx.redirectTo | 关闭当前页面,跳转到应用内的某个页面。 |
wx.reLaunch | 关闭所有页面,打开到应用内的某个页面。 |
uni.switchTab | 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面。使用其他跳转 API 来跳转到 tabbar会跳转失败。 |
wx.navigateBack | 关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages() 获取当前的页面栈,决定需要返回几层。 |
3.其他页面跳转回tabbar页面的方法
以这个小程序举例,在这个页面可以看到通过点击这些跳转后的页面返回时都得返回现在这个页面。
以入库记录为例,进去后又有很多的跳转,比如点击某条记录跳转到了详情页,其中点击了编辑又跳转到了另一个编辑页面,编辑完成后肯定得跳转回这个页面,这时候问题来了,直接返回的话就不是跳转回我们想要的tabbar页面了,因为栈中还存在其他的页面,需要一层层的出栈。可能有人会说可以使用navigateBack
,使用这个是可以跳回来,但是无法刷新页面,还得在onShow
生命周期再发起一次请求。而且需要自己算跳几次也比较麻烦。这时候我们就可以使用这个生命周期onBackPress
我们通过清空页面栈并且跳转回tabbar来达到我们想要的效果,这个最后的return true
非常关键,如果不写就达不到跳转到我们想要的页面的效果。当然使用这个生命周期不是只能跳回到tabbar页面,这个生命周期是监听返回的事件,我们也可以跳转到其他的页面,只需要把switchTab
换成redirectTo
即可。
onBackPress() {
uni.switchTab({
url: '/pages/manage/manage'
})
return true
},
这个生命周期是有参数传进入来的,我们可以避免掉通过navigateBack
跳过来的页面,否则容易出问题
onBackPress(options) {
if (options.from === 'navigateBack') {
return false
}
uni.redirectTo({ url: '/page/index' })
return true
},
然而这个生命周期只适用APP,H5和支付宝小程序,微信小程序是不支持这个api的,这时候我们就得专门对微信小程序做处理。onUnload
生命周期是所有端都通用的,我们只需要在页面卸载时调用微信原生的跳转到tabbar的api即可实现我们的效果,这样就可以多端都保持一致。
onUnload() {
//#ifdef MP-WEIXIN
wx.switchTab ({
url: '/pages/manage/manage'
})
//#endif
},
4.页面来回跳转保持数据的方法
一个页面跳转到另一个页面拿到数据后回到原先页面数据还需要维持原先的样子怎么来处理,这个时候就需要navigateBack
和getCurrentPages
结合起来了使用了。
举个例子,我希望在填写完入库日期备注后通过点击手动跳转到物资选择页面来去选择对应的物资进行入库,这时候如果通过常规的跳转的方式再次回到原先页面,那么之前填写的日期备注等数据就已经重置了,这并不是我们所期望的。
我们跳转到物资选择页面可以使用navigateTo
uni.navigateTo({
url: item.url,
})
在物资选择页面通过获取页面栈实例的方式拿到上一个页面,当我们选择完毕后将数据保存到原先页面定义的data中去,最后通过navigateBack
回到上一个页面,那么上一个页面之前填写的内容和现在选择完后的内容就都有了。
// 获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。
const pages = getCurrentPages()
const prevPage = pages[pages.length - 2] //上一个页面
//#ifdef H5
prevPage._data.selectData = this.selectMaterial
//#endif
//小程序中的修改方法
// #ifndef H5
prevPage.$vm._data.selectData = this.selectMaterial
//#endif
uni.navigateBack() //返回上一页面
本人也是刚接触uniapp不久,写的有问题的地方还望各位大佬指出,本文只是当自身的踩坑记录。如果对各位有帮助再好不过。
来源:https://juejin.cn/post/7094217394926649351


猜你喜欢
- 本文为大家分享了Python3实现发送QQ邮件功能:html,供大家参考,具体内容如下之前已经成功发送了qq邮件。下面贴出html格式的qq
- C# 连接oracle数据库常用的三种方法有三种:一、Oracle.ManagedDataAccess.dll:Oracle官方提供的ora
- 今天主要记录一下pandas去重复行以及如何分类汇总。以下面的数据帧作为一个例子: import pandas as pddata
- 细心的人都会发现GitHub个人主页有一个记录每天贡献次数的面板,我暂且称之为贡献面板。就像下图那个样子。只要当天在GitHub有提交记录,
- 数据库对于服务端开发人员来说,几乎就是左膀右臂。几乎每一个服务端开发人员都要和数据库打交道。而MySQL又以其开源免费,小巧玲珑,简单易用,
- 手机控件查看工具uiautomatorviewer工具简介用来扫描和分析Android应用程序的UI控件的工具.如何使用 1.进入
- 一、yield运行方式我们定义一个如下的生成器:def put_on(name): print("Hi {}, 货物来了,准备搬到
- 置信椭圆原理及椭圆图形绘制置信椭圆长短轴计算def confidence_oval(self,factor, ppf_rate): &nbs
- 数据库--用户表CREATE TABLE `users` ( `id` int(11) NOT NULL AUTO_
- 1.需求描述编写一个 Python 程序,每次下载压缩包形式的文件后,自动将内部文件解压到当前文件夹后将压缩包删除,通过本案例可以学到的知识
- 需求分析“员工刷脸考勤”系统,采用Python语言开发,可以通过摄像头添加员工面部信息,这里就涉及到两个具体的个问题,一个是应该以什么样的数
- 概述binlog2sql是一个Python开发开源的MySQL Binlog解析工具,能够将Binlog解析为原始的SQL,也支持将Binl
- 首先,我们来随便写一个带空格的列表:list1 = ['122','2333','3444'
- 校验是否全由数字组成function isDigit(s) { var patrn=/^[0-9]{1,20}$/; if (!patrn.
- 01、Pandas在数据分析师的日常工作中,70%到80%都涉及到理解和清理数据,也就是数据探索和数据挖掘。Pandas主要用于数据分析,这
- 项目中需要FusionCharts图表显示双Y轴,好像FCF_MSLine.swf不可以这样,只能显示一个Y轴,多条线, 找了一下,用MSC
- 本文实例讲述了PHP中round()函数对浮点数进行四舍五入的方法。分享给大家供大家参考。具体方法如下:语法:round(x,prec)参数
- 前提官网上提供了 Mac 和 Windows 上的安装包和 Linux 上安装需要的源码。下载地址如下:https://www.python
- 粒子群算法粒子群算法源于复杂适应系统(Complex Adaptive System,CAS)。CAS理论于1994年正式提出,CAS中的成
- 在该网站下载你所需要的mysql依赖驱动版本,比如我的QT版本是5.15就下5.15版的 按照你的Qt编译版本和机器位数进行下载,