uniapp返回上一级选择性刷新数据,不重新加载页面

在我们使用uniapp返回上一级页面时用到uni.navigateBack(),但是无法进行页面刷新,重新刷新整个页面又不能满足我们大部分时间的需求,此时可以通过监听器的方式,在页面触发返回时监听到变化,同时修改我们需要重新获取的数据。

话不多说,直接上代码

1. 返回上一个页面

 2. 获取上一级页面并触发更新

 通过getCurrentPages() 获取页面栈

 3. wacth监听 refresh

简单来说就是通过监听器来触发我们需要修改的数据

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值