激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - JS 的 六種打斷點(diǎn)的方式,你用過幾種?

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

2021-12-16 22:24神光的編程秘籍神說要有光zxg js教程

Debugger 是前端開發(fā)很重要的一個(gè)工具,它可以在我們關(guān)心的代碼處斷住,通過單步運(yùn)行來理清邏輯。而 Debugger 用的好壞與斷點(diǎn)打得好壞有直接的關(guān)系。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

Debugger 是前端開發(fā)很重要的一個(gè)工具,它可以在我們關(guān)心的代碼處斷住,通過單步運(yùn)行來理清邏輯。而 Debugger 用的好壞與斷點(diǎn)打得好壞有直接的關(guān)系。

Chrome Devtools 和 VSCode 都提供了 Debugger,它們支持的打斷點(diǎn)的方式有 6 種。

普通斷點(diǎn)

在想斷住的那一行左側(cè)單擊一下就可以添加一個(gè)斷點(diǎn),運(yùn)行到該處就會(huì)斷住。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

這是最基礎(chǔ)的斷點(diǎn)方式,VSCode 和 Chrome Devtools 都支持這種斷點(diǎn)。

條件斷點(diǎn)

右鍵單擊代碼所在的行左側(cè),會(huì)出現(xiàn)一個(gè)下拉框,可以添加一個(gè)條件斷點(diǎn)。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

輸入條件表達(dá)式,當(dāng)運(yùn)行到這一行代碼并且表達(dá)式的值非空時(shí)就會(huì)斷住,這比普通斷點(diǎn)靈活些。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

這種根據(jù)條件來斷住的斷點(diǎn) VSCode 和 Chrome Devtools 也都支持。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

DOM 斷點(diǎn)

在 Chrome Devtools 的 Elements 面板的對應(yīng)元素上右鍵,選擇 break on,可以添加一個(gè) dom 斷點(diǎn),也就是當(dāng)子樹有變動(dòng)、屬性有變動(dòng)、節(jié)點(diǎn)移除這三種情況的時(shí)候會(huì)斷住。可以用來調(diào)試導(dǎo)致 dom 變化的代碼。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

涉及到 DOM 的調(diào)試,只有 Chrome Devtools 支持這種斷點(diǎn)。

URL 斷點(diǎn)

在 Chrome Devtools 的 Sources 面板可以添加 XHR 的 url 斷點(diǎn),當(dāng) ajax 請求對應(yīng) url 時(shí)就會(huì)斷住,可以用來調(diào)試請求相關(guān)的代碼。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

這個(gè)功能只有 Chrome Devtools 有。

Event Listener 斷點(diǎn)

在 Chrome Devtools 的 Sources 面板還可以添加 Event Listener 的斷點(diǎn),指定當(dāng)發(fā)生什么事件時(shí)斷住,可以用來調(diào)試事件相關(guān)代碼。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

這個(gè)功能也是只有 Chrome Devtools 有。

異常斷點(diǎn)

在 VSCode 的 Debugger 面板勾選 Uncaught Exceptions 和 Caught Exceptions 可以添加異常斷點(diǎn),在拋出異常未被捕獲或者被捕獲時(shí)斷柱。用來調(diào)試一些發(fā)生異常的代碼時(shí)很有用。

JS 的 六種打斷點(diǎn)的方式,你用過幾種?

這個(gè)功能只有 VSCode 有。

總結(jié)

Debugger 打斷點(diǎn)的方式除了直接在對應(yīng)代碼行單擊的普通斷點(diǎn)以外,還有很多根據(jù)不同的情況來添加斷點(diǎn)的方式。

一共有六種:

  • 普通斷點(diǎn):運(yùn)行到該處就斷住
  • 條件斷點(diǎn):運(yùn)行到該處且表達(dá)式為真就斷住,比普通斷點(diǎn)更靈活
  • DOM 斷點(diǎn):DOM 的子樹變動(dòng)、屬性變動(dòng)、節(jié)點(diǎn)刪除時(shí)斷住,可以用來調(diào)試引起 DOM 變化的代碼
  • URL 斷點(diǎn):URL 匹配某個(gè)模式的時(shí)候斷住,可以用來調(diào)試請求相關(guān)代碼
  • Event Listener 斷點(diǎn):觸發(fā)某個(gè)事件監(jiān)聽器的時(shí)候斷住,可以用來調(diào)試事件相關(guān)代碼
  • 異常斷點(diǎn):拋出異常被捕獲或者未被捕獲的時(shí)候斷住,可以用來調(diào)試發(fā)生異常的代碼

這些打斷點(diǎn)方式大部分都是 Chrome Devtools 支持的(普通、條件、DOM、URL、Event Listener),也有的是 VSCode Debugger 支持的(普通、條件、異常)。

不同情況下的代碼可以用不同的打斷點(diǎn)方式,這樣調(diào)試代碼會(huì)高效很多。

JS 的六種打斷點(diǎn)方式,你用過幾種呢?

原文鏈接:https://mp.weixin.qq.com/s/jpjgp3g04j2wooZsBHmrBA

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99久久婷婷国产综合精品青牛牛 | 怦然心动50免费完整版 | 91精品久久香蕉国产线看观看 | 亚洲成人精品国产 | 成片免费观看大全 | 欧美一级精品 | 精品偷拍久久 | 嗯~啊~用力~高h | 欧美人一级淫片a免费播放 久久久久久久久91 国产99久久久久久免费看 | 精品一区二区久久久久久按摩 | 久久久精品精品 | fc2国产成人免费视频 | 成年免费大片黄在线观看岛国 | 免费观看视频网站 | 黄在线观看 | 请播放一级毛片 | 热99精品视频 | 中韩毛片 | av日韩一区二区 | 精品1| 国产高潮失禁喷水爽到抽搐视频 | 成人av一区二区免费播放 | 成人在线免费视频播放 | 成人毛片网 | 亚久久 | 日韩大片在线永久观看视频网站免费 | 九一看片. | 国产精品www | 亚洲男人的天堂在线视频 | 成人免费淫片视频软件 | 成人在线第一页 | 91久久精品一二三区 | 国产精品美女久久久免费 | 久久免费视频一区 | 综合97 | 久久网站热最新地址4 | 韩日黄色片| 毛片网站视频 | 亚洲国产一区二区三区 | 久久久看| 欧美激情在线播放 |