欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序全局變量改變監(jiān)聽的實現方法

 更新時間:2019年07月15日 09:52:46   作者:Dream_saddle  
這篇文章主要給大家介紹了關于微信小程序全局變量改變監(jiān)聽的實現方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用微信小程序具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

問題來源

最近工作需要寫小程序頁面,其中有個頁面情況為:父頁面中包含了一個組件頁面,組件頁面中又包含了另外一個組件頁面。

需求為:點擊最后一個組件頁面中的一個view,需要顯示最外層父頁面中的一個彈出層,并且動態(tài)的展示值,這個值的來源就是最后一個組件頁面中的內容。

處理辦法

當時想到的就是使用全局變量,在 app.js 中定義好全局變量,點擊組件頁面時就修改全局變量的值,父頁面同樣使用全局變量的值,這樣一來就可以動態(tài)打開/關閉彈出層且傳遞值了。

下面先看看 app.js 中怎么定義的:

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

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

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

那么,就需要監(jiān)聽 globalData 中的屬性了。

首先是 app.js:

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

接下來就是在組件頁面事件中動態(tài)賦值:

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

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

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

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

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

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

可以參考:http://www.dbjr.com.cn/article/165365.htm

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關文章

  • 淺談ECMAScript 中的Array類型

    淺談ECMAScript 中的Array類型

    這篇文章主要介紹了淺談ECMAScript 中的Array類型,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06
  • js Array對象的擴展函數代碼

    js Array對象的擴展函數代碼

    有時候我們需要對js的array對象擴展一些功能,這里簡單介紹下,方便需要的朋友
    2013-04-04
  • javascript計算當月剩余天數(天數計算器)示例代碼

    javascript計算當月剩余天數(天數計算器)示例代碼

    本文介紹了利用Javascript在網頁上計算當前月份的剩余天數的方法,大家參考使用吧
    2014-01-01
  • javascript 利用arguments實現可變長參數

    javascript 利用arguments實現可變長參數

    在C#中,有可變長參數params[],但是在js中,如何實現這種可變參數呢?本片文章主要介紹利用arguments,實現可變長參數。有需要的請參考下
    2016-11-11
  • JS原生2048小游戲源碼分享(全網最新)

    JS原生2048小游戲源碼分享(全網最新)

    這篇文章主要介紹了JS原生2048小游戲源碼分享,實現代碼全部是給予js實現的,代碼簡單易懂對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • JavaScript?12個有用的數組技巧

    JavaScript?12個有用的數組技巧

    數組是Javascript最常見的概念之一,它為我們提供了處理數據的許多可能性,熟悉數組的一些常用操作是很有必要的。本文將為大家介紹12個有用的JavaScript數組技巧,需要的朋友可以參考一下
    2021-12-12
  • JavaScript學習筆記之取值函數getter與取值函數setter詳解

    JavaScript學習筆記之取值函數getter與取值函數setter詳解

    這篇文章主要介紹了JavaScript取值函數getter與取值函數setter,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 改進UCHOME的記錄發(fā)布,增強可訪問性用戶體驗

    改進UCHOME的記錄發(fā)布,增強可訪問性用戶體驗

    今天是看到UCDChina上的一篇文章文章 ,是關于SNS的用戶體驗問題,發(fā)覺文中提到的第一個細節(jié),UCHOME就做的不好,于是改進了一下。
    2011-01-01
  • 微信小程序實現天氣預報功能

    微信小程序實現天氣預報功能

    這篇文章主要為大家詳細介紹了微信小程序實現天氣預報功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • 一張Web前端的思維導圖分享

    一張Web前端的思維導圖分享

    這篇文章主要介紹了一張Web前端的思維導圖分享,本文直接給出思維導圖,圖中詳細描述了一些需要學習的知識、一些必備的知識,需要的朋友可以參考下
    2015-07-07

最新評論