微信小程序返回上一頁傳參並刷新


問題

微信小程序onLoad(options)方法在整個生命周期中只加載一次,也就是你進入下個頁面,再返回時,是不會再次觸發的,所以你返回是url傳參是行不通了。

需求

現在有這么一個需求:一個商品支付頁面,點擊優惠卷進入優惠券列表頁,選中優惠券后帶着數據再返回到支付頁面。

方法

一、使用到的方法是小程序的頁面棧,感興趣可以打印一下pages的內容,就是你頁面跳轉的軌跡數組,最后一項就是當前頁面,倒數第二個就是上一頁。很好理解,因為在當前頁停止了,肯定是最后一個

//獲取頁面棧
let pages = getCurrentPages();
//獲取所需頁面
let currPage = pages[pages.length - 1];//當前頁面
let prevPage = pages[pages.length -2];//上一頁

二、在支付頁把需要再次刷新的數據都放到onShow()方法中,不需要刷新的放到onLoad()方法中

思路

1、我們的目標是把優惠券的數據渲染到支付頁上,所以先在優惠券頁面點擊優惠券的時候通過頁面棧獲取到上一頁(也就是支付頁),將本條數據動態添加到支付頁的data中

//獲取頁面棧
let pages = getCurrentPages();
//獲取所需頁面
let prevPage = pages[pages.length -2];//上一頁
prevPage.setData({
    yourData:yourData,//你需要傳過去的數據
});

2、將需要刷新的數據放到onShow()方法中

//這里展示在onShow方法中獲取當前頁onLoad方法中的options
onShow:function(){
    let pages = getCurrentPages();
    let currPage = pages[pages.length - 1];
    //當前頁的options,啥意思呢,就是你可能某個函數需要刷新,但是他的參數正好是傳過來的參數
    console.log(currPage.options);  
}

你在優惠券頁點擊之后,因為你的數據已經存到支付頁了,所以返回支付頁后,你可以直接在data中獲取到你需要的數據,進行你需要的操作。

Ok,這就完事了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM