使用JavaScript給物件修改註冊監聽器
我們在開發一些大型前端專案時,會遇到這樣一種情況,某個變數上有個欄位。我們想知道是哪一段程式修改了這個變數上的欄位。比如全域性變數window上我們自定義了一個新欄位_name,我們想知道到底有哪些程式給這個欄位賦了值。
一行行地除錯肯定太費時間了。如果window這個變數的_name欄位被程式賦值時,能執行我們自己實現的一個監聽器,這樣不就方便多了麼?
監聽器的實現很簡單:
<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>
使用Object物件自帶的方法defineProperty, 第一個引數為要監聽的物件window,第二個引數為要監聽的物件欄位名稱,_name。
第三個引數是一個物件,屬性為set,意思是我們想監聽window._name被賦值的這個事件。屬性set的值為一個JavaScript函式,即我們自己定義的監聽器。這個監聽器,當window._name被其他JavaScript函式修改之後,就會觸發。
測試一下,在瀏覽器裡執行上述程式碼,發現斷點按照我們期望的被觸發了:
從呼叫棧也能發現確實是window._name = “2”這一行程式碼觸發的斷點,我們自己註冊的屬性修改監聽器確實工作了。
相關文章
- rac監聽不能動態註冊
- Nacos - 事件的註冊、取消與監聽(EventDispatcher)事件
- js 註冊事件的兩種方式詳解,傳統註冊事件與方法監聽註冊事件(addEventListener)JS事件dev
- 監聽 watch props物件屬性監聽 或深度監聽物件
- JavaScript 事件監聽JavaScript事件
- 使用 TypeScript 自定義裝飾器給類的方法增添監聽器 ListenerTypeScript
- 【Spring註解開發】元件註冊-使用@Configuration和@Bean給容器中註冊元件Spring元件Bean
- Oracle 19C 監聽無法動態註冊例項Oracle
- 使用 TypeScript 自定義裝飾器給類的屬性增添監聽器 ListenerTypeScript
- ORACLE之手動註冊監聽listener。alter system set local_listener="XXX"Oracle
- 安卓使用物理鍵監聽器安卓
- 資料庫無法註冊至監聽服務解決辦法資料庫
- VOS3000 註冊埠修改S3
- 12C RAC 修改監聽埠
- JavaScript物件參考手冊JavaScript物件
- JavaScript監聽屬性改變JavaScript
- 監聽瀏覽器返回,pushState,popstate 事件,window.history物件瀏覽器事件物件
- vue監聽input是否為空(監聽值為物件某個屬性)Vue物件
- JMeter—監聽器(十二)JMeter
- oracle之 單例項監聽修改埠Oracle單例
- 監聽檔案修改的四種方法
- Oracle 修改預設監聽埠故障分析Oracle
- JavaScript 監聽子節點改變JavaScript
- 監聽器和過濾器過濾器
- 一次Oracle監聽無法動態註冊處理過程排查分析Oracle
- 如何註冊及使用ChatGPT?【伺服器篇】ChatGPT伺服器
- python使用裝飾器實現的事件中心(監聽器)Python事件
- Spring中如何優雅的使用監聽器模式Spring模式
- JavaScript 註冊事件處理函式JavaScript事件函式
- 事件和事件監聽器事件
- javaWeb中的監聽器JavaWeb
- 如何移除事件監聽器事件
- JavaScript監聽後代節點改變JavaScript
- JavaScript實時監聽input中值變化JavaScript
- jfinal中如何使用過濾器監控Druid監聽SQL執行?過濾器UISQL
- oracle 12c 資料庫例項監聽無法註冊問題一例Oracle資料庫
- 論如何監聽一個物件的變化物件
- 如何使用 controllerExtensions 給 SAP Fiori Elements 表格註冊事件響應函式Controller事件函式