微信小程序navigateBack更新上一页数据
微信小程序开发过程中经常有这种需求,需要把当前页面数据传递给上一个页面,或者刷新上一页数据,但是wx.navigateBack()无法传递数据。
注:执行wx.navigateBack()回退至上一个页面,上一页面只会回调onShow方法
解决方案:
- 上一页面在onShow方法刷新数据
- 利用页面栈,在当前页面主动调用上一页面生命周期方法或普通方法
getCurrentPages() 函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。
重点就在这里,在当前页面拿到上一个页面的实例对象,然后调用该对象的方法完成数据传递。
//登陆成功跳转
var pages = getCurrentPages(); //获取当前页面信息栈
console.log("pages.length: " + pages.length)
if (pages.length > 1) {
//上一个页面实例对象
var prePage = pages[pages.length - 2];
//关键:上一个页面重加载
prePage.onLoad()
//返回
wx.navigateBack({
//delta: pages.length
delta: 1
})
}
这样就可以实现数据传递给上一个页面,要注意上一个页面必须使用wx.navigateTo跳转到当前页面,不能使用wx.redirectTo,这样会关闭上一个页面,导致当前页面无法获取上一页Page实例。
版权声明:
作者:Joe.Ye
链接:https://www.appblog.cn/index.php/2023/03/25/wechat-mini-program-navigateback-update-previous-page-data/
来源:APP全栈技术分享
文章版权归作者所有,未经允许请勿转载。
共有 0 条评论