亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

小程序跨頁面之間通信的方式有哪些

發布時間:2021-08-17 11:28:16 來源:億速云 閱讀:361 作者:小新 欄目:移動開發

這篇文章給大家分享的是有關小程序跨頁面之間通信的方式有哪些的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

1、localStorage + onShow

應用場景: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')
    },
})

2、globalData + onShow

應用場景: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';
    },
})

3、小程序本身提供的 EventChannel

應用場景:主要是 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)
    })
  }
})

4、自定義EventBus

應用場景: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');
    },
})

5、獲取頁面棧實例 getCurrentPages

應用場景:主要是 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');
        }
    },
})

6、globalData proxy

暫時未試驗這種方式,原理上可行;

相應的原理可參考Vue3的數據劫持和訂閱通知相結合;

感謝各位的閱讀!關于“小程序跨頁面之間通信的方式有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

五指山市| 攀枝花市| 苍溪县| 岳池县| 南充市| 定兴县| 随州市| 凤阳县| 报价| 腾冲县| 丰顺县| 吴川市| 修文县| 卓尼县| 黑水县| 平安县| 西贡区| 云林县| 澜沧| 吕梁市| 伊宁市| 凤翔县| 福泉市| 巴东县| 锡林浩特市| 疏附县| 宁乡县| 浦城县| 米泉市| 玉环县| 台南县| 尚志市| 丽江市| 长沙市| 环江| 汕尾市| 曲阳县| 广昌县| 抚顺县| 青神县| 天峻县|