uniapp 返回上一级页面并触发指定方法
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小时之内自觉删除。
若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。