利用Object.defineProperty挂接set钩子,监控对象属性的修改事件
生活随笔
收集整理的這篇文章主要介紹了
利用Object.defineProperty挂接set钩子,监控对象属性的修改事件
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
測試代碼:
<html> <script> "use strict"; function test(){Object.defineProperty(window, "_name", {get : function(){ console.log("gett is called ") },set : function(newValue){ debugger;console.log("_name is filled!!!!");},enumerable : true,configurable : true});for( var i = 0; i < 2; i++) console.log(i);window._name = "2"; };test(); </script>通過第5行開始的Object.defineProperty, 給window全局對(duì)象的_name屬性設(shè)置了一個(gè)set hook,這樣每當(dāng)該屬性被update時(shí),注冊的set hook會(huì)自動(dòng)被調(diào)用:
測試:
一旦第18行window._name = 2被執(zhí)行:
set hook會(huì)自動(dòng)觸發(fā):
要獲取更多Jerry的原創(chuàng)文章,請關(guān)注公眾號(hào)"汪子熙":
總結(jié)
以上是生活随笔為你收集整理的利用Object.defineProperty挂接set钩子,监控对象属性的修改事件的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: “中国龙芯之母”黄令仪逝世:66 岁出山
- 下一篇: 在Google Cloud platfo