Movatterモバイル変換


[0]ホーム

URL:


TryMCP servers to extend agent mode in VS Code!

Dismiss this update

Browser debugging in VS Code

Visual Studio Code includes a built-in debugger for Edge and Chrome. There are a couple ways to get started with it.

We also have more detailed walkthroughs to get started withReact,Angular, andVue, as well as other debuggingrecipes.

Open Link command

The simplest way to debug a webpage is through theDebug: Open Link command found in the Command Palette (⇧⌘P (Windows, LinuxCtrl+Shift+P)). When you run this command, you'll be prompted for a URL to open, and the debugger will be attached.

Using the Open Link command to attach to a URL

If your default browser is Edge, VS Code will use it to open the page. Otherwise, it will try to find an installation of Chrome on your system instead.

Launch configuration

Launch configs are the traditional way to set up debugging in VS Code, and provide you the most flexibility for running complex applications.

In this section, we'll go into more detail about configurations and features for more advanced debugging scenarios. Instructions for Node.jsstepping over external code also apply to browser-based debugging.

Note: If you are just getting started with VS Code, you can learn about general debugging features and creatinglaunch.json configuration files in theDebugging topic.

Launching browsers

In most cases, you'll want to start a new instance of the browser to debug your webpage or file. To do this, you can create a file named.vscode/launch.json that looks like this:

{  "version":"0.2.0",  "configurations": [    {      "type":"msedge",      "request":"launch",      "name":"Launch my cool app",      "url":"http://localhost:8000"    }  ]}

When you hitF5 or theStart button in theRun and Debug view,http://localhost:8000 will be opened in debug mode. If you'd like to use Chrome instead of Edge, replacemsedge withchrome.

You can also debug a single file without running a server, for example:

{  "version":"0.2.0",  "configurations": [    {      "type":"msedge",      "request":"launch",      "name":"Launch hello.html",      "file":"${workspaceFolder}/hello.html"    }  ]}

Attaching to browsers

To attach to a running browser, it needs to be launched in a special debug mode. You can do this using the following command, replacingedge.exe with the path to your Edge or Chrome binary:

edge.exe --remote-debugging-port=9222 --user-data-dir=remote-debug-profile

Setting the--remote-debugging-port tells the browser to listen on that port for a debug connection. Setting a separate--user-data-dir forces a new instance of the browser to be opened; if this flag isn't given, then the command will open a new window of any running browser and not enter debug mode.

Next, add a new section to thevscode/launch.json file as below:

{  "version":"0.2.0",  "configurations": [    {      "type":"msedge",      "request":"attach",      "name":"Attach to browser",      "port":9222    }  ]}

Now, you can pressF5 or theStart button in theRun and Debug view to attach to the running browser. You can even add anaddress property to debug a browser running on a different machine.

Launch configuration attributes

Debugging configurations are stored in alaunch.json file located in your workspace's.vscode folder. An introduction into the creation and use of debugging configuration files is in the generalDebugging article. You can either "launch" a browser with your application, or "attach" to an existing browser that youstarted in debug mode.

Below is a reference of commonlaunch.json attributes specific to browser debugging. You can view the complete set of options in thevscode-js-debug options documentation.

  • webRoot - The root directory for your source code. Most often, and by default, thewebRoot is your workspace folder. This option is used for sourcemap resolution.
  • outFiles - An array ofglob patterns for locating generated JavaScript files. See the section onSource maps.
  • smartStep- Try to automatically step over source code that doesn't map to source files. See the section onSmart stepping.
  • skipFiles - Automatically skip files covered by theseglob patterns. See the section onSkipping uninteresting code.
  • trace - Enable diagnostic output.

These attributes are only available for launch configurations of request typelaunch:

  • url - The URL to automatically open when the browser is launched.
  • runtimeExecutable - Either an absolute path to the browser executable to use, or the version of the browser to use. Valid versions includestable (default),canary,beta, anddev.
  • runtimeArgs - Optional arguments passed when launching the browser.

These attributes are only available for launch configurations of request typeattach:

  • url - If given, VS Code will attach to a tab with this URL. If not provided, it will attach to all browser tabs.
  • port - Port to use for remote debugging the browser, matching the--remote-debugging-port used when starting the browser. See the section onAttaching to Browsers.
  • address - IP address or hostname the debugged browser is listening on. See the section onAttaching to Browsers.

WebAssembly Debugging

WebAssembly debugging in browsers is identical to Node.js,read more about WebAssembly Debugging here.

Source Maps

The JavaScript debugger in VS Code supports source maps that allow debugging transformed code. For example, TypeScript code is compiled to JavaScript, and many web applications bundle all their JavaScript files together. The source map helps the debugger figure out how to map between your original code, and the code running in the browser.

Most modern tools used for building web applications will work out of the box. If not, our section onsourcemaps in Node.js contains guidance that applies to browser debugging as well.

Loading Source Maps

Each JavaScript file may reference a source map, by a URL or relative path. When dealing with web applications, you'll want to make sure that the URL is something the debugger running in VS Code can access. If it can't, you'll see errors in theDebug Console explaining which source maps failed to load, and why.

If it can't access it directly, VS Code will try to use the browser's network stack to request the source map. This provides an opportunity for any authentication state or network settings in the browser to be applied to the request. For example, if your source maps are in a location guarded by cookie authentication, VS Code can load them if and only if the browser session has the necessary cookies.

Next steps

07/09/2025

[8]ページ先頭

©2009-2025 Movatter.jp