第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

觀察現(xiàn)有對象上的對象屬性變化

觀察現(xiàn)有對象上的對象屬性變化

慕尼黑8549860 2021-06-29 09:07:23
過去可以調(diào)用Object.observe()任何對象,然后在修改屬性時接收回調(diào)。但是,它已被棄用,我們獲得了代理、getter 和 setter作為替代方案。但都不允許將偵聽器附加到現(xiàn)有對象,該對象的引用已存儲在其他地方。以這段代碼為例:const state = {};/* BEGIN Third party code */(function runProcessing() {    setInterval(globalState => {        if (Math.random() > 0.5) {            globalState.attr = !globalState.attr;        }    }, 1000, state);})();/* END Third party code */// TODO: run some function every time state.attr is changed有兩個直接的問題:state被聲明為 a const,因此不能使用 Proxy 重新定義state通過引用傳遞給內(nèi)部函數(shù),因此即使state重新定義,該函數(shù)仍將繼續(xù)使用原始對象雖然這可以通過setInterval不斷地將其state.attr與之前版本的自身進(jìn)行比較來實現(xiàn),但它無法捕捉到setInterval調(diào)用之間發(fā)生的變化,并且總是會有滯后。是否有任何鮮為人知的方法可以實現(xiàn)這一目標(biāo)?
查看完整描述

1 回答

?
Cats萌萌

TA貢獻(xiàn)1805條經(jīng)驗 獲得超9個贊

Object.defineProperties分別使用 Object.defineProperty在現(xiàn)有對象上創(chuàng)建 getter 和 setter。


查看完整回答
反對 回復(fù) 2021-07-08
  • 1 回答
  • 0 關(guān)注
  • 246 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號