当前位置:首页 > 编程技术 > 正文内容

uniapp 返回上一级页面并触发指定方法

yc8881年前 (2022-12-02)编程技术242

1. 问题描述


当前有三个页面: 个人中心(pages/user/index)、个人信息(pages/user/info)、修改姓名(pages/user/name)

正确逻辑: 修改姓名的操作步骤是在个人中心点击 设置 的图标,进入个人信息页面,在个人信息页面点击姓名进入修改姓名的页面,点击保存或左上角的返回键回到个人信息页面,并且显示最新的姓名。三个页面及操作步骤如下所示:

个人中心 -> 个人信息 -> 修改姓名

uniapp 的路由跳转 API :

  • uni.navigateTo() 保留当前页,跳转到非 tabBar 页

  • uni.redirectTo() 关闭当前页,跳转到非 tabBar 页

  • uni.reLaunch() 关闭所有页面,打开到应用内的某个页面

  • uni.navigateBack() 关闭当前页,返回上一页面或多级页面

更多路由跳转 API 查看官方文档: https://uniapp.dcloud.net.cn/api/router.html

起初因为 uniapp 的路由跳转 API 有好多种,对他们不太熟悉,不知道使用哪个好,后面导致页面跳转存在问题

方案 1: 起初我只考虑修改了姓名的情况,未考虑进入修改姓名页面但并没有修改姓名,然后通过返回键返回个人信息页。这种跳转方式用法在修改姓名的情况下是没有问题的,但如果没有修改姓名,点击了修改姓名页的返回键将直接回到个人中心页,而不是个人信息页,因为个人信息页到修改姓名页时使用的 uni.redirectTo()

个人中心 -> 个人信息: uni.navigateTo()个人信息 -> 修改姓名: uni.redirectTo()修改姓名 -> 个人信息: uni.redirectTo()

方案 2: 进入修改姓名页,点击返回键回到个人信息页,那么个人信息页跳转到修改姓名页必须使用 uni.navigateTo() :

个人中心 -> 个人信息: uni.navigateTo()个人信息 -> 修改姓名: uni.navigateTo()

要想满足我们的功能需求,只需在方案 2 的基础上兼容修改姓名时页面操作流程也正确就可以了,通过查找资料和请教同事得知可以返回上一级页面并调用上一级页面中的方法,这种写法正好解决了我的问题

// 当前页面栈的实例let pages = getCurrentPages()// 上一个页面实例对象let beforePage = pages[pages.length - 2]// 触发上一个页面中的 getUserInfo 方法beforePage.$vm.getUserInfo()// 返回上一个页面uni.navigateBack()

2. 解决方案


三个页面之间的跳转方式

个人中心 -> 个人信息: uni.navigateTo()个人信息 -> 修改姓名: uni.navigateTo()修改姓名 -> 个人信息: uni.navigateBack()

当姓名修改成功后弹出消息提示,然后调用个人信息页的 getUserInfo 方法重新获取姓名,最后返回到个人信息页即可

uni.showToast({    title: '修改成功',    duration: 1500})setTimeout(() => {    // 当前页面栈的实例    let pages = getCurrentPages()    // 上一个页面实例对象    let beforePage = pages[pages.length - 2]    // 触发上一个页面中的 getUserInfo 方法    beforePage.$vm.getUserInfo()    // 返回上一个页面    uni.navigateBack()}, 1500);


本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/10150.html

标签: uniapp
分享给朋友:

“uniapp 返回上一级页面并触发指定方法” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

今天在安装MySQL时出现starting the server失败,经过查询分析得出以下结论,记录一下操作步骤。原因分析:如果电脑是第一次安装MySQL,一般不会出现这样的报错。如下图所示。star...

【说站】vagrant实现linux虚拟机的安装并配置网络

【说站】vagrant实现linux虚拟机的安装并配置网络

一、VirtualBox的下载和安装1、下载VirtualBox官网下载:https://www.virtualbox.org/wiki/Downloads我的电脑是Windows的,所以下载Wind...

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

PDF中的墨迹注释(Ink Annotation),表现为徒手涂鸦式的形状;该类型的注释,可任意指定形状顶点的位置及个数,通过指定的顶点,程序将连接各点绘制成平滑的曲线。下面,通过C#程序代码介绍如何...