微信小程序全局變量改變監(jiān)聽(tīng)的實(shí)現(xiàn)方法
問(wèn)題來(lái)源
最近工作需要寫(xiě)小程序頁(yè)面,其中有個(gè)頁(yè)面情況為:父頁(yè)面中包含了一個(gè)組件頁(yè)面,組件頁(yè)面中又包含了另外一個(gè)組件頁(yè)面。
需求為:點(diǎn)擊最后一個(gè)組件頁(yè)面中的一個(gè)view,需要顯示最外層父頁(yè)面中的一個(gè)彈出層,并且動(dòng)態(tài)的展示值,這個(gè)值的來(lái)源就是最后一個(gè)組件頁(yè)面中的內(nèi)容。
處理辦法
當(dāng)時(shí)想到的就是使用全局變量,在 app.js 中定義好全局變量,點(diǎn)擊組件頁(yè)面時(shí)就修改全局變量的值,父頁(yè)面同樣使用全局變量的值,這樣一來(lái)就可以動(dòng)態(tài)打開(kāi)/關(guān)閉彈出層且傳遞值了。
下面先看看 app.js 中怎么定義的:
globalData: {
openid: '',
userInfo: null,
_showPictureDetail: false,
_pictureTime: '',
_pictureAddress: '',
//改變量用戶存放全局變量修改過(guò)程中的值傳遞, 傳遞對(duì)象
data: {}
}
在其他頁(yè)面就使用 getApp().globalData.參數(shù)名 = 值 的形式來(lái)改變參數(shù)值, 使用 getApp().globalData.參數(shù)名 的形式來(lái)獲取值。
這樣能正常賦值,但是由于都是在同一個(gè)界面展示,我需要更新值后,馬上得到最新的值。上面簡(jiǎn)單的設(shè)置獲取就不起作用了。
那么,就需要監(jiān)聽(tīng) globalData 中的屬性了。
首先是 app.js:
//app 全局屬性監(jiān)聽(tīng)
watch: function (method) {
var obj = this.globalData;
Object.defineProperty(obj, "data", { //這里的 data 對(duì)應(yīng) 上面 globalData 中的 data
configurable: true,
enumerable: true,
set: function (value) { //動(dòng)態(tài)賦值,傳遞對(duì)象,為 globalData 中對(duì)應(yīng)變量賦值
this._showPictureDetail = value.showPictureDetail;
this._pictureTime = value.pictureTime;
this._pictureAddress = value.pictureAddress;
method(value);
},
get: function () { //獲取全局變量值,直接返回全部
return this.globalData;
}
})
},
接下來(lái)就是在組件頁(yè)面事件中動(dòng)態(tài)賦值:
//圖片拍攝詳情查看
viewPictureDetailInfo: function (e) {
// 修改 app 全局屬性值, 由于 globalData.data 是個(gè)對(duì)象,因?yàn)樯婕暗叫薷亩鄠€(gè)參數(shù),所以需要傳遞對(duì)象
app.globalData.data = {
'_showPictureDetail': true,
'_pictureTime': e.currentTarget.dataset.phototime,
'_pictureAddress': e.currentTarget.dataset.address
}
},
最后就是在最外層父頁(yè)面添加 app.js 監(jiān)聽(tīng)回調(diào),動(dòng)態(tài)修改變量值,以達(dá)到動(dòng)態(tài)打開(kāi)/關(guān)閉彈出層和展示內(nèi)容了:
// 首先需要在父頁(yè)面 onLoad() 方法中添加監(jiān)聽(tīng)以及指定監(jiān)聽(tīng)回調(diào)方法
// 設(shè)置 App 監(jiān)聽(tīng)回調(diào)
// 如果其他頁(yè)面修改了 app.js 中的 showPictureDetail 值, 就會(huì)觸發(fā)回調(diào)
getApp().watch(self.watchBack)
//定義監(jiān)聽(tīng)回調(diào)方法
//app 監(jiān)聽(tīng)回調(diào)方法
watchBack: function (value) { //這里的value 就是 app.js 中 watch 方法中的 set, 返回整個(gè) globalData
this.setData({
showPictureDetail: value._showPictureDetail,
pictureTime: value._pictureTime,
pictureAddress: value._pictureAddress
});
},
這樣,在父頁(yè)面中使用 showPictureDetail..這幾個(gè)變量就可以動(dòng)態(tài)展示了。
PS:我這邊的業(yè)務(wù)需求涉及到多個(gè)變量的監(jiān)聽(tīng),如果你只有一個(gè)變量的監(jiān)聽(tīng),那么只需要修改 app.js 中 watch 方法的 Object.defineProperty 內(nèi)容由對(duì)象傳遞變?yōu)閱蝹€(gè)值傳遞即可。在更新值和獲取值時(shí)傳遞就是一個(gè)值,而不是對(duì)象。
可以參考:http://www.dhdzp.com/article/165365.htm
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
javascript在IE下trim函數(shù)無(wú)法使用的解決方法
這篇文章主要介紹了javascript在IE下trim函數(shù)無(wú)法使用的解決方法,分別敘述了javascript以及jQuery下的解決方案,對(duì)于WEB前端javascript設(shè)計(jì)人員進(jìn)行瀏覽器兼容性調(diào)試有不錯(cuò)的借鑒價(jià)值,需要的朋友可以參考下2014-09-09
Javascript模仿淘寶信用評(píng)價(jià)實(shí)例(附源碼)
這篇文章主要介紹了Javascript模仿淘寶信用評(píng)價(jià)功能實(shí)現(xiàn)方法,以完整實(shí)例形式分析了JavaScript響應(yīng)鼠標(biāo)事件動(dòng)態(tài)改變頁(yè)面元素的相關(guān)技巧,并附帶了完整的實(shí)例代碼供讀者下載參考,需要的朋友可以參考下2015-11-11
jquery結(jié)合CSS使用validate實(shí)現(xiàn)漂亮的驗(yàn)證
這篇文章主要介紹了jquery結(jié)合CSS使用validate實(shí)現(xiàn)漂亮的驗(yàn)證,需要的朋友可以參考下2015-01-01
JavaScript利用鍵盤(pán)碼控制div移動(dòng)
這篇文章主要為大家詳細(xì)介紹了JavaScript利用鍵盤(pán)碼控制div移動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
淺談JavaScript的自動(dòng)垃圾收集機(jī)制
本文主要對(duì)JavaScript的自動(dòng)垃圾收集機(jī)制進(jìn)行簡(jiǎn)要分析,并介紹了垃圾收集的方式:標(biāo)記清除(mark-and-sweep)和引用計(jì)數(shù)(reference counting),需要的朋友一起來(lái)看下吧2016-12-12
Js判斷兩個(gè)數(shù)組是否相等的幾種常見(jiàn)場(chǎng)景
無(wú)論是在開(kāi)發(fā)中還是面試時(shí),在js中判斷變量是否相等,都是一個(gè)比較常見(jiàn)的問(wèn)題,這篇文章主要給大家介紹了關(guān)于Js判斷兩個(gè)數(shù)組是否相等的幾種常見(jiàn)場(chǎng)景,需要的朋友可以參考下2024-07-07
BootStrapTable 單選及取值的實(shí)現(xiàn)方法
學(xué)習(xí)bootstrapTable 一直沒(méi)有找到 單選框的選定的和取值的教程,接下來(lái)通過(guò)本文給大家分享BootStrapTable 單選及取值的實(shí)現(xiàn)方法,非常不錯(cuò),需要的朋友參考下2017-01-01
JS創(chuàng)建優(yōu)美的頁(yè)面滑動(dòng)塊效果 - Glider.js
JS創(chuàng)建優(yōu)美的頁(yè)面滑動(dòng)塊效果 - Glider.js...2007-09-09

