您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關小程序跨頁面之間通信的方式有哪些的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
應用場景:A->B/B->A 都可
優點:簡單操作,易理解
缺點:調用到storage,有可能設置失敗;且設置后是持久緩存,可能污染原邏輯,應及時刪除
應用示例:
// 以A->B示例 // A 頁面 Page({ onShow(){ if(wx.getStorageSync('$datas')){ console.log(wx.getStorageSync('$datas')) // 11111 } }, }) // B 頁面 Page({ someActions(){ wx.setStorageSync('$datas','11111') }, })
應用場景:A->B/B->A 都可
優點:簡單操作,易理解;直接操作globalData對象,相比于storage執行效率更高
缺點:設置后是小程序生命周期內都可訪問,可能污染原邏輯,應及時刪除
應用示例:
// 以A->B示例 // A 頁面 const app = getApp(); Page({ onShow(){ if(app.globalData.$datas){ console.log(app.globalData.$datas) // 11111 } }, }) // B 頁面 const app = getApp(); Page({ someActions(){ app.globalData.$datas = '11111'; }, })
應用場景:主要是 B->A
優點:小程序原生提供,可隨時銷毀
缺點:僅限制在navigateTo
中,且要求基礎庫版本不低于2.7.3
應用示例:
// A頁面 wx.navigateTo({ url: 'B?id=1', events: { // 為指定事件添加一個監聽器,獲取被打開頁面傳送到當前頁面的數據 acceptDataFromOpenedPage: function(data) { console.log(data) }, someEvent: function(data) { console.log(data) } ... }, success: function(res) { // 通過eventChannel向被打開頁面傳送數據 res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'test' }) } }) // B頁面 Page({ onLoad: function(option){ console.log(option.query) const eventChannel = this.getOpenerEventChannel() eventChannel.emit('acceptDataFromOpenedPage', {data: 'test'}); eventChannel.emit('someEvent', {data: 'test'}); // 監聽acceptDataFromOpenerPage事件,獲取上一頁面通過eventChannel傳送到當前頁面的數據 eventChannel.on('acceptDataFromOpenerPage', function(data) { console.log(data) }) } })
應用場景:A->B/B->A 都可
優點:自定義實現,可擴展
缺點:對wx進行擴展自定義變量,相同eventName可能會重復綁定監聽事件
EventBus: 參考這篇EventBus實現
應用示例:
// app.js const EventBus = require('./utils/eventBus.js'); App({ onLaunch(){ // 將eventBus初始到wx上 wx['$uhomesBus'] = (function () { if (wx['$uhomesBus']) return wx['$uhomesBus']; return new EventBus(); })(); } }) // A頁面 Page({ someActions(){ wx.$uhomesBus.$on('$datas',(data)=>{ console.log(data); // 11111 }) }, }) // B頁面 Page({ emitActions(){ wx.$uhomesBus.$emit('$datas', '11111'); }, })
應用場景:主要是 B->A
優點:小程序原生提供,處理邏輯基本都在B頁面
缺點:需要增加匹配頁面的相應規則,且路由棧至少有兩個頁面存在
應用示例:
// A頁面 Page({ someActions(datas){ console.log(datas); // 11111 }, }) // B頁面 Page({ someActions(){ const pages = getCurrentPages(); if (pages.length < 2) return; // 如果頁面層級較多,可用循環去匹配到A頁面; // 此處僅做2個頁面的示例 const prevPage = pages[pages.length - 1]; // 路由匹配到A if (prevPage.route === 'A') { prevPage.someActions('11111'); } }, })
暫時未試驗這種方式,原理上可行;
相應的原理可參考Vue3的數據劫持和訂閱通知相結合;
感謝各位的閱讀!關于“小程序跨頁面之間通信的方式有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。