您好,登錄后才能下訂單哦!
小編給大家分享一下小程序頁面間傳遞數據的方式有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
使用wx.navigateTo
與 wx.redirectTo
的時候,可以將部分數據放在 url 里面,并在新頁面 onLoad
的時候獲取且初始化。
//pageA.js // Navigate wx.navigateTo({ url: '../pageB/pageB?name=lin&gender=male', }) // Redirect wx.redirectTo({ url: '../pageB/pageB?name=lin&gender=male', }) // pageB.js ... Page({ onLoad: function(option){ console.log(option.name + 'is' + option.gender); this.setData({ option: option }); } })
需要注意的問題:
使用wx.navigateTo
與 wx.redirectTo
時,不允許跳轉到 tab 所包含的頁面;
onLoad
只執行一次;
適用:
這種方式一般適用于少數頁面之間需要少量數據傳遞,如B頁面需要A頁面中的1-2個數據等等。
在 app.js 文件中定義全局變量 globalData
,舊頁面將要傳遞的數據賦值存放在里面,新頁面調用全局變量獲取傳遞數據值。
// app.js App({ // 全局變量 globalData: { name: null } }) //pageA.js ··· getApp().globalData.name = "lin"; //pageB.js ··· this.setData({ userName: getApp().globalData.name });
要注意的問題:
使用的時候,直接使用 getApp()
拿到存儲的信息。
適用:
這種方式一般適用于多個頁面或者全部頁面都需要獲取使用同一個數據,比如一開始進入首頁就獲取到的用戶信息等;
使用小程序中的本地緩存Storage
,舊頁面將傳遞數據存入緩存中,新頁面通過調用獲取緩存的API得到數據。
//pageA.js ··· wx.setStorageSync('sessionId', res.sessionId); //pageB.js ··· var sessionId = wx.getStorageSync('sessionId');
要注意的問題:
Storage每次存入會覆蓋掉原來該 key 對應的內容。
如果用戶主動刪除小程序或因存儲空間原因被系統清理,Storage中數據將被清除。
單個 key 允許存儲的最大數據長度為 1MB,所有數據存儲上限為 10MB。
適用:
這種方式一般適用于即使小程序退出然后再重新進入,也要保留的數據,類似于登錄狀態的保留等。
以上是“小程序頁面間傳遞數據的方式有哪些”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。