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);
更新于:14天前相关文章
- 【说站】python系统内置方法如何获取
- 【说站】java反射三种方法
- 【说站】python字符串格式化的方法整理
- 【说站】python代码提速有哪些方法
- 【说站】python ElementTree解析的方法
- 【说站】python shutil有哪些操作文件的方法
- 【说站】java泛型方法的使用注意
- 【说站】java泛型方法的特征
- 宝塔服务器上404页面怎么配置的操作教程
- iOS 图片压缩方法的示例代码
- thinkphp怎么用u方法?ThinkPHP中U方法的使用浅析
- thinkphp怎么用model?ThinkPHP中实例Model方法的区别说明
- thinkPHP简单调用函数与类库的方法
- uniapp 中 vuex 的使用
- HTTP请求方法(HTTP Request Method)
- JS 的 apply 方法
- JS 数组去重的多种方法
- uniapp 国际化开发指南【多语言】
- JS 数组方法 every 和 some 的区别
- uniapp 网络请求封装【luch-request 3.x】