:::moniker range=">= aspnetcore-1.1 < aspnetcore-6.0" By [Nicolò Carandini](https://github.com/ncarandini) and [Tom Dykstra](https://github.com/tdykstra) Browser Link is a Visual Studio feature. It creates a communication channel between the development environment and one or more web browsers. Use Browser Link to: * Refresh your web app in several browsers at once. * Test across multiple browsers with specific settings such as screen sizes. * Select UI elements in browsers in real-time, see what markup and source it's correlated to in Visual Studio. * Conduct real-time browser test automation. Browser Link is also extensible. ## Browser Link setup :::moniker-end :::moniker range=">= aspnetcore-3.0 < aspnetcore-6.0" Add the [Microsoft.VisualStudio.Web.BrowserLink](https://www.nuget.org/packages/Microsoft.VisualStudio.Web.BrowserLink/) package to your project. For ASP.NET Core Razor Pages or MVC projects, also enable runtime compilation of Razor (`.cshtml`) files as described in . Razor syntax changes are applied only when runtime compilation has been enabled. :::moniker-end :::moniker range=">= aspnetcore-2.1 <= aspnetcore-2.2" When converting an ASP.NET Core 2.0 project to ASP.NET Core 2.1 and transitioning to the [Microsoft.AspNetCore.App metapackage](xref:fundamentals/metapackage-app), install the [Microsoft.VisualStudio.Web.BrowserLink](https://www.nuget.org/packages/Microsoft.VisualStudio.Web.BrowserLink/) package for Browser Link functionality. The ASP.NET Core 2.1 project templates use the `Microsoft.AspNetCore.App` metapackage by default. :::moniker-end :::moniker range="= aspnetcore-2.0" The ASP.NET Core 2.0 **Web Application**, **Empty**, and **Web API** project templates use the [Microsoft.AspNetCore.All metapackage](xref:fundamentals/metapackage), which contains a package reference for [Microsoft.VisualStudio.Web.BrowserLink](https://www.nuget.org/packages/Microsoft.VisualStudio.Web.BrowserLink/). Therefore, using the `Microsoft.AspNetCore.All` metapackage requires no further action to make Browser Link available for use. :::moniker-end :::moniker range="<= aspnetcore-1.1" The ASP.NET Core 1.x **Web Application** project template has a package reference for the [Microsoft.VisualStudio.Web.BrowserLink](https://www.nuget.org/packages/Microsoft.VisualStudio.Web.BrowserLink/) package. Other project types require you to add a package reference to `Microsoft.VisualStudio.Web.BrowserLink`. :::moniker-end :::moniker range=">= aspnetcore-1.1 < aspnetcore-6.0" ### Configuration Call `UseBrowserLink` in the `Startup.Configure` method: ```csharp app.UseBrowserLink(); ``` The `UseBrowserLink` call is typically placed inside an `if` block that only enables Browser Link in the Development environment. For example: ```csharp if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); app.UseBrowserLink(); } ``` For more information, see . ## How to use Browser Link When you have an ASP.NET Core project open, Visual Studio shows the Browser Link toolbar control next to the **Debug Target** toolbar control: ![Browser Link drop-down menu](~/client-side/using-browserlink/_static/browserLink-dropdown-menu.png) From the Browser Link toolbar control, you can: * Refresh the web app in several browsers at once. * Open the **Browser Link Dashboard**. * Enable or disable **Browser Link**. Note: Browser Link is disabled by default in Visual Studio. * Enable or disable [CSS Auto-Sync](#enable-or-disable-css-auto-sync). ## Refresh the web app in several browsers at once To choose a single web browser to launch when starting the project, use the drop-down menu in the **Debug Target** toolbar control: ![F5 drop-down menu](~/client-side/using-browserlink/_static/debug-target-dropdown-menu.png) To open multiple browsers at once, choose **Browse with...** from the same drop-down. Hold down the Ctrl key to select the browsers you want, and then click **Browse**: ![Open many browsers at once](~/client-side/using-browserlink/_static/open-many-browsers-at-once.png) The following screenshot shows Visual Studio with the Index view open and two open browsers: ![Sync with two browsers example](~/client-side/using-browserlink/_static/sync-with-two-browsers-example.png) Hover over the Browser Link toolbar control to see the browsers that are connected to the project: ![Hover tip](~/client-side/using-browserlink/_static/hoover-tip.png) Change the Index view, and all connected browsers are updated when you click the Browser Link refresh button: ![Browsers sync to changes](~/client-side/using-browserlink/_static/browsers-sync-to-changes.png) Browser Link also works with browsers that you launch from outside Visual Studio and navigate to the app URL. ### The Browser Link Dashboard Open the **Browser Link Dashboard** window from the Browser Link drop down menu to manage the connection with open browsers: ![open-browserslink-dashboard](~/client-side/using-browserlink/_static/open-browserlink-dashboard.png) If no browser is connected, you can start a non-debugging session by selecting the **View in Browser** link: ![Browserlink dashboard no connections](~/client-side/using-browserlink/_static/browserlink-dashboard-no-connections.png) Otherwise, the connected browsers are shown with the path to the page that each browser is showing: ![Browserlink dashboard two connections](~/client-side/using-browserlink/_static/browserlink-dashboard-two-connections.png) You can also click on an individual browser name to refresh only that browser. ### Enable or disable Browser Link When you re-enable Browser Link after disabling it, you must refresh the browsers to reconnect them. ### Enable or disable CSS Auto-Sync When CSS Auto-Sync is enabled, connected browsers are automatically refreshed when you make any change to CSS files. ## How it works Browser Link uses [SignalR](xref:signalr/introduction) to create a communication channel between Visual Studio and the browser. When Browser Link is enabled, Visual Studio acts as a SignalR server that multiple clients (browsers) can connect to. Browser Link also registers a middleware component in the ASP.NET Core request pipeline. This component injects special ` ``` Your source files aren't modified. The middleware component injects the script references dynamically. Because the browser-side code is all JavaScript, it works on all browsers that SignalR supports without requiring a browser plug-in. :::moniker-end