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

溫馨提示×

溫馨提示×

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

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

怎么在微信小程序中監聽全局變量

發布時間:2021-05-26 11:00:36 來源:億速云 閱讀:738 作者:Leah 欄目:web開發

今天就跟大家聊聊有關怎么在微信小程序中監聽全局變量,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

globalData: {
 openid: '',
 userInfo: null,
 _showPictureDetail: false,
 _pictureTime: '',
 _pictureAddress: '',
 //改變量用戶存放全局變量修改過程中的值傳遞, 傳遞對象
 data: {}
 }

在其他頁面就使用 getApp().globalData.參數名 = 值 的形式來改變參數值, 使用 getApp().globalData.參數名 的形式來獲取值。

這樣能正常賦值,但是由于都是在同一個界面展示,我需要更新值后,馬上得到最新的值。上面簡單的設置獲取就不起作用了。

那么,就需要監聽 globalData 中的屬性了。

首先是 app.js:

//app 全局屬性監聽
 watch: function (method) {
 var obj = this.globalData;
 Object.defineProperty(obj, "data", { //這里的 data 對應 上面 globalData 中的 data
 configurable: true,
 enumerable: true,
 set: function (value) { //動態賦值,傳遞對象,為 globalData 中對應變量賦值
 this._showPictureDetail = value.showPictureDetail;
 this._pictureTime = value.pictureTime;
 this._pictureAddress = value.pictureAddress;
 method(value);
 },
 get: function () { //獲取全局變量值,直接返回全部
 return this.globalData;
 }
 })
 },

接下來就是在組件頁面事件中動態賦值:

//圖片拍攝詳情查看
 viewPictureDetailInfo: function (e) {
 // 修改 app 全局屬性值, 由于 globalData.data 是個對象,因為涉及到修改多個參數,所以需要傳遞對象
 app.globalData.data = {
 '_showPictureDetail': true,
 '_pictureTime': e.currentTarget.dataset.phototime,
 '_pictureAddress': e.currentTarget.dataset.address
 }
 },

最后就是在最外層父頁面添加 app.js 監聽回調,動態修改變量值,以達到動態打開/關閉彈出層和展示內容了:

// 首先需要在父頁面 onLoad() 方法中添加監聽以及指定監聽回調方法
// 設置 App 監聽回調
// 如果其他頁面修改了 app.js 中的 showPictureDetail 值, 就會觸發回調
getApp().watch(self.watchBack)

//定義監聽回調方法
//app 監聽回調方法
 watchBack: function (value) { //這里的value 就是 app.js 中 watch 方法中的 set, 返回整個 globalData
 this.setData({
 showPictureDetail: value._showPictureDetail,
 pictureTime: value._pictureTime,
 pictureAddress: value._pictureAddress
 });
 },

這樣,在父頁面中使用 showPictureDetail..這幾個變量就可以動態展示了。

PS:我這邊的業務需求涉及到多個變量的監聽,如果你只有一個變量的監聽,那么只需要修改 app.js 中 watch 方法的 Object.defineProperty 內容由對象傳遞變為單個值傳遞即可。在更新值和獲取值時傳遞就是一個值,而不是對象。

看完上述內容,你們對怎么在微信小程序中監聽全局變量有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

AI

林口县| 兴安县| 淮南市| 龙陵县| 白玉县| 客服| 安徽省| 长治县| 得荣县| 涟源市| 永济市| 陕西省| 三河市| 古浪县| 张家口市| 新蔡县| 丹寨县| 手机| 新沂市| 乌拉特中旗| 平舆县| 成武县| 拉孜县| 旬阳县| 北海市| 新邵县| 仙桃市| 射阳县| 右玉县| 酒泉市| 扶沟县| 互助| 大方县| 濉溪县| 晋中市| 富宁县| 木兰县| 雷山县| 赤水市| 新晃| 平湖市|