--- title: Debug Razor Components author: guardrex description: Learn how to debug Blazor and Razor Components apps. monikerRange: '>= aspnetcore-3.0' ms.author: riande ms.custom: mvc ms.date: 01/29/2019 uid: razor-components/debug --- # Debug Razor Components [Daniel Roth](https://github.com/danroth27) [!INCLUDE[](~/includes/razor-components-preview-notice.md)] Razor Components has some *very early* support for debugging client-side Blazor apps running on WebAssembly in Chrome. While this initial debugging support is very limited and unpolished, it shows the basic debugging infrastructure coming together. To debug a client-side Blazor app in Chrome: * Build a Blazor app in `Debug` configuration (the default for non-published apps). * Run the Blazor app in Chrome (version 70 or later). * With the keyboard focus on the app (not in the dev tools panel, which you should probably close for a less confusing debugging experience), select the following Blazor-specific keyboard shortcut: * `Shift+Alt+D` on Windows/Linux * `Shift+Cmd+D` on macOS Run Chrome with remote debugging enabled to debug the Blazor app. If remote debugging is disabled, an error page is generated by Chrome. The error page contains instructions for running Chrome with the debugging port open so that the Blazor debugging proxy can connect to the app. *Close all Chrome instances* and restart Chrome as instructed. ![Blazor debugging error page](https://user-images.githubusercontent.com/1874516/43123091-01ec0796-8ed8-11e8-844c-23b4e6e9d069.png) Once Chrome is running with remote debugging enabled, the debugging keyboard shortcut opens a new debugger tab. After a moment, the *Sources* tab shows a list of the .NET assemblies in the app. Expand each assembly and find the *.cs*/*.cshtml* source files available for debugging. Set breakpoints, switch back to the app's tab, and the breakpoints are hit. After a breakpoint is hit, single-step (`F10`) or resume (`F8`) normally. ![Blazor debugging](https://user-images.githubusercontent.com/1874516/43123060-efb0b3b0-8ed7-11e8-9ea5-97aa34247a0b.png) Blazor provides a debugging proxy that implements the [Chrome DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/) and augments the protocol with .NET-specific information. When debugging keyboard shortcut is pressed, Blazor points the Chrome DevTools at the proxy. The proxy connects to the browser window you're seeking to debug (hence the need to enable remote debugging). You might be wondering why we don't just use browser source maps. Source maps allow the browser to map compiled files back to their original source files. However, Blazor does not map C# directly to JS/WASM (at least not yet). Instead, Blazor does IL interpretation within the browser, so source maps aren't relevant. Note that the debugger capabilities are **very limited**. You can currently only: * Set and remove breakpoints. * Single-step through the code or resume (`F8`). * In the *Locals* display, observe the values of any local variables of type `int`, `string`, and `bool`. * See the call stack, including call chains that go from JavaScript into .NET and from .NET to JavaScript. You *can't*: * Observe the values of any locals that aren't an `int`, `string`, or `bool`. * Observe the values of any class properties or fields. * Hover over variables to see their values * Evaluate expressions in the console. * Step across async calls. * Perform most other ordinary debugging scenarios. Development of further debugging scenarios is an on-going focus of the engineering team. ## Troubleshooting tip If you're running into errors, the following tip may help: In the **debugger** tab, open the developer tools in your browser. In the console, execute `localStorage.clear()` to remove any breakpoints.