天天看點

善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置

我今天的工作又遇到一個難題。前端UI右下角這個按鈕被設定為"禁用(disabled)"狀态。

善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置
這個按鈕的可用狀态由屬性enabled控制。我通過調試發現,一旦下圖第88行代碼執行完畢之後,這個按鈕的屬性mProperties裡就多出一個enabled:false的屬性。
善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置
而88行執行之前,還沒有這個enabled:false的屬性。正是這個屬性讓按鈕進入了禁用狀态。
善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置

我單步調試setModel函數,花了半個小時的時間也沒能找到這個enabled屬性到底是在哪一行代碼加進去的。

于是我隻有尋求其他辦法。我想到了Object.defineProperty這個方法:

善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置
善用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;}});           
善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置

現在就來試試。果然斷點自動觸發了。我成功找到了我在尋找的給mProperties添加了enabled = false的代碼位置。

善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置
善用Object.defineProperty巧妙找到修改某個變量的準确代碼位置

要擷取更多Jerry的原創技術文章,請關注公衆号"汪子熙"