欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用vscode調(diào)試編譯后的js代碼詳解

 更新時間:2018年05月14日 08:43:02   作者:梅旭光  
看了網(wǎng)上好多在vscode上調(diào)試javascript的代碼,總是出現(xiàn)問題,索性自己寫一個,下面這篇文章主要給大家介紹了關(guān)于如何利用vscode調(diào)試編譯后的js代碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們一起來看看吧

前言

在開發(fā)的過程中,幾乎不可能一次性就能寫出毫無破綻的程序,斷點調(diào)試代碼是一個普遍的需求。

vscode 是一個非常棒的編輯器,內(nèi)置功能強大的調(diào)試能力。經(jīng)過簡單的設(shè)定,就可以對 js 文件進(jìn)行調(diào)試。但有時我們想要調(diào)試的內(nèi)容是經(jīng)過編譯的,當(dāng)然我們可以直接調(diào)試編譯后的代碼。但經(jīng)過編譯壓縮以后的代碼,可讀性很差,且也可能無法分模塊查看了,有什么方法進(jìn)行編譯前的代碼調(diào)試么?答案當(dāng)然是肯定的。

下面話不多說了,來一起看看詳細(xì)的介紹吧。

vscode 的常規(guī)調(diào)試

vscode 的調(diào)試界面在窗口最左邊:

最新版本的vscode,該選項默認(rèn)隱藏了,需要自己打開。

首次打開調(diào)試界面時,當(dāng)前沒有任何調(diào)試配置,我們可以點擊齒輪 icon 添加一個:

選擇 nodejs 后,會自動在當(dāng)前工程目錄下添加 .vscode/launch.json 文件,這個文件就是 vscode 調(diào)試配置文件。

一個簡易的配置文件內(nèi)容為:

{
 // 使用 IntelliSense 了解相關(guān)屬性。 
 // 懸停以查看現(xiàn)有屬性的描述。
 // 欲了解更多信息,請訪問: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
 {
 "type": "node",
 "request": "launch",
 "name": "啟動程序",
 "program": "${workspaceFolder}/index.js"
 }
 ]
}

上面這個配置所做的工作是啟動當(dāng)前目錄下的 index.js 文件進(jìn)行調(diào)試。

我們也可以設(shè)置每次摁 F5 時自動調(diào)試當(dāng)前打開的文件,只需要修改 program:

{
 "program": "${file}"
}

調(diào)試編譯后的文件

想要調(diào)試編譯后的文件,需要對 launch.json 文件進(jìn)行設(shè)置。

vscode 要想調(diào)試編譯后的代碼,他需要知道哪些代碼是經(jīng)過編譯的,且需要知道編譯后的代碼與編譯前代碼的對應(yīng)關(guān)系。

其實理論上 vscode 是可以把每個要執(zhí)行的文件都認(rèn)為是編譯后的文件,進(jìn)行源文件的查找?我猜是因為性能原因,我們需要自己指定哪些文件是編譯后的文件。在 launch.json 中,使用outFiles屬性來指定編譯后的產(chǎn)出文件:

{
 "version": "0.2.0",
 "configurations": [
 {
 // 省略其他設(shè)置...
 "outFiles": [
 "${workspaceFolder}/lib/*.js",
 ]
 // ...
 }
 ]
}

雖然有些麻煩,但好在我們可以使用通配符。

現(xiàn)在有了編譯后的文件,vscode 還需要知道源文件,以及編譯后文件與源文件的對應(yīng)關(guān)系,聽著有沒有很熟悉?這個過程就是通過 sourcemap 來進(jìn)行實現(xiàn)的。

我們需要在編譯 js 文件時生成相應(yīng)的 .map 文件,并在產(chǎn)出 js 文件后面附加 .map 文件的地址:

//@ sourceMappingURL=./index.js.map

ok,現(xiàn)在 vscode 在執(zhí)行 js 文件時,會從 outFile 中查找是否是編譯后的代碼,如果是,就通過 sourcemap 映射到源代碼,方便我們進(jìn)行調(diào)試。

自動執(zhí)行編譯

現(xiàn)在我們的開發(fā)流程變成了:修改源代碼 -> 編譯源代碼 -> 調(diào)試。

為了方便,我們可以設(shè)置preLaunchTask屬性,該屬性的作用是每次調(diào)試前執(zhí)行一個前置任務(wù),我們可以把編譯過程放在前置任務(wù)里。

首先我們需要來配置一個task,task的配置文件在 .vscode/tasks.json,可以打開 command palette (⇧⌘P (Windows, Linux Ctrl+Shift+P)) 選擇“任務(wù):配置任務(wù)”自動生成一個:

{
 // See https://go.microsoft.com/fwlink/?LinkId=733558
 // for the documentation about the tasks.json format
 "version": "2.0.0",
 "tasks": [
 {
 "label": "build",
 "type": "npm",
 "script": "build",
 "problemMatcher": []
 }
 ]
}

這里我們配置了npm run build作為前置任務(wù),每次執(zhí)行調(diào)試時都會先進(jìn)行 build。

示例配置文件

{
 // 使用 IntelliSense 了解相關(guān)屬性。 
 // 懸停以查看現(xiàn)有屬性的描述。
 // 欲了解更多信息,請訪問: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
 {
 "type": "node",
 "request": "launch",
 "name": "example",
 "program": "${workspaceFolder}/index.js",
 "preLaunchTask": "build",
 "cwd": "${workspaceFolder}",
 "outFiles": [
 "${workspaceFolder}/lib/*.js"
 ]
 }

相關(guān)文檔

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論