善用Object.defineProperty巧妙找到修改某個變數的準確程式碼位置
我今天的工作又遇到一個難題。前端UI右下角這個按鈕被設定為”禁用(disabled)”狀態。
這個按鈕的可用狀態由屬性enabled控制。我通過除錯發現,一旦下圖第88行程式碼執行完畢之後,這個按鈕的屬性mProperties裡就多出一個enabled:false的屬性。
而88行執行之前,還沒有這個enabled:false的屬性。正是這個屬性讓按鈕進入了禁用狀態。
我單步除錯setModel函式,花了半個小時的時間也沒能找到這個enabled屬性到底是在哪一行程式碼加進去的。
於是我只有尋求其他辦法。我想到了Object.defineProperty這個方法:
我在Chrome開發者工具裡執行如下程式碼,首先根據button的ID用ui.byId方法找到這個被禁用按鈕的例項,然後用Object.defineProperty給按鈕例項的屬性集合mProperties注入一個get方法,實現體只有一個debugger語句。如此一來,每次button的mProperties被訪問時,都會自動觸發一個斷點。而mProperties屬性發生變化時,必定會先產生讀取動作,因此斷點停下來時,我通過觀察呼叫棧的上下文就能夠找到是哪一行程式碼修改了mProperties。
var ui = sap.ui.getCore();
var button = ui.byId("button97DXvDVKUawkYgK3YQVram_64");
Object.defineProperty(button, "mProperties", { get: function(){ debugger;}});
現在就來試試。果然斷點自動觸發了。我成功找到了我在尋找的給mProperties新增了enabled = false的程式碼位置。
要獲取更多Jerry的原創技術文章,請關注公眾號”汪子熙”
相關文章
- 如何找到SAP UI5控制元件ID生成的準確時間點和程式碼位置UI控制元件
- 如何找到 SAP Spartacus 裡某個 Component TypeScript 編譯後生成的 JavaScript 位置TypeScript編譯JavaScript
- 五顏六色的程式碼:論程式碼的正確位置
- 使用DOM Breakpoints找到修改屬性的Javascript程式碼JavaScript
- 位置變數變數
- 關於如何能夠快速找到某個文字在所有檔案中的出現位置
- Spring框架裡解析配置檔案的準確位置Spring框架
- Shell程式設計-shell變數2-位置變數和預定義變數程式設計變數
- 準確的後一萬5個萬能碼+σσ5224110
- 如何使用Chrome找到Marketing Cloud某個contact的guidChromeCloudGUI
- 獲取母字串中某個子字串的某個確定的index值字串Index
- 某個OA系統的程式碼審計
- 找到一個數最接近的比它大的2的n次冪的程式碼分析
- Oracle RAC修改引數檔案位置Oracle
- 如何找到某個 ABAP structure 某欄位的源頭來自哪個資料庫表Struct資料庫
- 如何在MacOS中修改程式塢的位置?Mac
- Git回滾程式碼到某個commitGitMIT
- 由一個bug找到JS挖礦程式碼JS
- 網站模板文字內容修改,如何在網站後臺或程式碼編輯器中準確修改模板文字內容網站
- 怎樣修改網站產品價格,確保價格準確網站
- 網站文字錯誤怎麼修改啊,確保內容準確網站
- vue(js) 拖拽改變排序(陣列)位置(原理及程式碼)VueJS排序陣列
- 當程式碼變更遇上精準測試的總結
- win10修改個人文件位置的方法_win10我的文件位置如何更改Win10
- 快速找到最近修改的檔案!
- 反射修改 static final 變數反射變數
- 如何找到某個鍵值在索引中存在於哪個BLOCK中索引BloC
- 監聽視窗大小改變,同時根據視窗大小修改某個元素的大小
- Linux檢視某個程序的環境變數,以及重定向後的輸出Linux變數
- linux 查詢某個日期以後修改過哪些檔案 shell指令碼Linux指令碼
- 兩個修改Docker本地映象與容器的儲存位置的方法Docker
- Mac 設定環境變數的位置、檢視和新增PATH環境變數Mac變數
- RAC環境修改spfile的位置
- threeJs 修改TransformControls的顯示位置JSORM
- 修改linux最大檔案控制程式碼數Linux
- 變數C++邏輯程式碼變數C++
- Blade 模板,輸出 PHP 變數到 JavaScript 指令碼中的正確方式PHP變數JavaScript指令碼
- 如何找到SAP UI5裡阻止頁面繼續載入的出問題的具體程式碼位置UI