您好,登錄后才能下訂單哦!
自從node6.3以來,node已經直接支持類似node-inpect的功能,只要對執行的js代碼加入一個--inspect參數,即可使用chrome做代碼調試。
本文使用如下工具:
首先準備待調試代碼。如果這是為了學習的目的,可以使用我測試用代碼為:
var objectRegExp = /^\[object (\S+)\]$/; function gettype(obj) { var type = typeof obj; if (type !== 'object') { return type; } // inspect [[Class]] for objects return toString.call(obj) .replace(objectRegExp, '$1'); } gettype({}) gettype(function(){})
然后運行此代碼,加上參數--inspect-brk
node --inspect-brk a.js
系統提示:
Debugger listening on ws://127.0.0.1:9229/84960765-5abc-4236-a7c6-924f99c34ed7
打開瀏覽器,在地址欄內輸入:
chrome://inspect/#devices
可以看到:
Remote Target #LOCALHOST Target (v9.5.0) a.js file:///Users/lcj/Documents/github/express/a.js inspect
點擊最后一行inspect,即可彈出一個新的窗口,此為調試器。并且調入代碼到chrome調試器內,在執行命令的控制臺上可以看到:
Debugger attached.
現在,可以使用點擊調試器內的Run | Step | Step Into等按鈕做調試了。
對于沒有直接使用node執行的代碼,比如測試用例mocha,怎么辦?mocha也是支持這些選項的,比如express使用了mocha做單元測試,可以用如下命名來做調試:
mocha --require test/support/env --reporter spec --bail --check-leaks --no-exit test/app.router.js --inspect-brk -g 'should decode correct params
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。