uniapp返回上一页并刷新数据方法

let pages = getCurrentPages(); // 当前页面
let beforePage = pages[pages.length - 2]; // 上一页
uni.navigateBack({
    success: function() {
        beforePage.onLoad(); // 执行上一页的onLoad方法
    }
});

1.getCurrentPages()获取当前页面的页面栈,是个数组

2.pages[pages.length-1],为当前页。pages[pages.length-2]为上一页

3.let beforePage=pages[pages.length-2],将上一页赋值给beforePage

4.beforePage.onLoad()。调用上一页中的onload()方法

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用uni-app提供的页面生命周期函数和uni.navigateTo()方法来实现返回一页面并刷新页面重新根据接口获取数据的功能。 具体实现方法如下: 1. 在页面的onLoad()生命周期函数中,调用接口获取数据并将数据保存在页面的data中。 2. 在页面的onShow()生命周期函数中,判断是否需要重新获取数据。如果需要,则调用接口获取数据并将数据保存在页面的data中。 3. 在页面的onUnload()生命周期函数中,清空页面的data数据。 4. 在页面中设置一个返回按钮,并在按钮的点击事件中使用uni.navigateTo()方法返回一页面。 5. 在上一页面的onShow()生命周期函数中,判断是否需要刷新数据。如果需要,则调用接口获取数据并更新页面。 下面是一个示例代码: ``` // 返回按钮的点击事件 goBack() { uni.navigateTo({ url: '../previousPage/previousPage' }) } // 当前页面的生命周期函数 onLoad() { // 调用接口获取数据并保存在data中 // ... }, onShow() { if (this.needRefresh) { // 调用接口获取数据并保存在data中 // ... this.needRefresh = false; } }, onUnload() { // 清空data中的数据 // ... } // 上一页面的生命周期函数 onShow() { if (this.needRefresh) { // 调用接口获取数据并更新页面 // ... this.needRefresh = false; } } ``` 需要注意的是,示例代码中的this.needRefresh是一个标记变量,用于判断是否需要重新获取数据刷新数据。你可以根据实际情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值