May 19th, 2020

Blazor WebAssembly 3.2.0 now available

Daniel Roth
Principal Product Manager

I’m thrilled to announce that Blazor WebAssembly is now officially released. This is a fully-featured and supported release of Blazor WebAssembly that is ready for production use. Full stack web development with .NET is now here!

Get started

Getting started with Blazor WebAssembly is easy: simply go to https://blazor.net and install the latest .NET Core SDK (3.1.300 or later), which includes everything you need to build and run Blazor WebAssembly apps.

You can then create and run your first Blazor WebAssembly app by running:

dotnet new blazorwasm -o BlazorApp1
cd BlazorApp1
dotnet run

Browse to https://localhost:5001 and voilà! You’ve just built and run your first Blazor WebAssembly app!

Running Blazor WebAssembly app

To maximize your Blazor productivity, be sure to install a supported version of Visual Studio for your platform of choice:

You can find additional docs and samples on https://blazor.net.

Upgrade an existing project

If you already have an existing Blazor WebAssembly project, you can upgrade it from the 3.2.0 Release Candidate to the official 3.2.0 release by doing the following:

  • Update all Microsoft.AspNetCore.Components.WebAssembly.* and System.Net.Http.Json package references to version 3.2.0.

That’s it, you’re all set!

What is Blazor WebAssembly?

In case this is your first time learning about Blazor, let me introduce you to what Blazor WebAssembly is all about.

Blazor is an open source and cross-platform web UI framework for building single-page apps using .NET and C# instead of JavaScript. Blazor is based on a powerful and flexible component model for building rich interactive web UI. You implement Blazor UI components using a combination of .NET code and Razor syntax: an elegant melding of HTML and C#. Blazor components can seamlessly handle UI events, bind to user input, and efficiently render UI updates.

Blazor components can then be hosted in different ways to create your web app. The first supported way is called Blazor Server. In a Blazor Server app, the components run on the server using .NET Core. All UI interactions and updates are handled using a real-time WebSocket connection with the browser. Blazor Server apps are fast to load and simple to implement. Support for Blazor Server is available with .NET Core 3.1 LTS.

Blazor WebAssembly is now the second supported way to host your Blazor components: client-side in the browser using a WebAssembly-based .NET runtime. Blazor WebAssembly includes a proper .NET runtime implemented in WebAssembly, a standardized bytecode for the web. This .NET runtime is downloaded with your Blazor WebAssembly app and enables running normal .NET code directly in the browser. No plugins or code transpilation are required. Blazor WebAssembly works with all modern web browsers, both desktop and mobile. Similar to JavaScript, Blazor WebAssembly apps run securely on the user’s device from within the browser’s security sandbox. These apps can be deployed as completely standalone static sites without any .NET server component at all, or they can be paired with ASP.NET Core to enable full stack web development with .NET, where code can be effortlessly shared with the client and server.

Fully-featured

Blazor WebAssembly comes packed with features to keep you productive on your next web app project:

Blazor in action

Blazor WebAssembly has everything you need to build fully-featured production web apps. To see all these Blazor WebAssembly features in action, checkout Steve Sanderson’s on-demand BUILD session (link should be live after 12pm PT): Modern Web UI with Blazor WebAssembly.

Ready-made components

Of course, any web app is going to need beautiful and feature rich components. A variety of Blazor UI components are available from our fantastic partners that work great in any Blazor app, including Blazor WebAssembly apps:

Open-source community

Blazor also has a thriving open-source community and ecosystem. Members of the community, (folks just like you!) have built lots of great component libraries, interop libraries, test frameworks, and more, and then made them freely available for you to use. Some great examples include:

You can find these community projects and many others listed on the Awesome Blazor GitHub repo.

LTS or Current?

Blazor WebAssembly 3.2.0 is a fully supported release under the .NET Core Support Policy. Since this is the first release of Blazor WebAssembly, it is a Current release, not an LTS release; it does not the inherit LTS status of .NET Core 3.1. This means that once Blazor WebAssembly ships with .NET 5 later this year, you will need to upgrade to .NET 5 within three months to stay in support. We expect Blazor in .NET 5 to be a highly compatible release.

What’s next?

Now that we have shipped Blazor WebAssembly, we are shifting our attention to .NET 5. Work has already started on making Blazor WebAssembly available with .NET 5, which we expect to complete for preview next month.

We also have a number of Blazor features and improvements that we are investigating for the .NET 5 & 6 wave. You can see the list of core deliverables that we are considering in the Blazor Roadmap for .NET 5 issue on GitHub. Please note that we consider this list to be highly aspirational. While we hope to deliver all of the improvements listed, there are still many unknown and plans will certainly change as we go. We also expect that there will be plenty of smaller improvements that we will deliver as well.

We are also continuing to collaborate with our friends on the Xamarin team on experimental support for building native UI using Blazor through the Mobile Blazor Bindings project. This includes some early efforts to explore building hybrid UI for native apps, which we hope to share more about soon.

Thank you

We sincerely appreciate all the enthusiastic support we have received from the Blazor community as we’ve worked to make the release a reality. The number of Blazor articles, blog posts, docs, sample apps, libraries, books, videos, presentations, workshops, courses, meetups, feature suggestions, and feedback issues that have been contributed by the community to the Blazor ecosystem even while it was still in preview has been truly outstanding. To everyone who helped make this release possible, thank you! We couldn’t have done it without you.

Try Blazor today

We hope you enjoy this release of Blazor WebAssembly. Give Blazor a try today by going to https://blazor.net. We look forward to seeing what you create with it.

As always, if you have any questions of feedback about Blazor please let us know by filing an issue on GitHub.

Author

Daniel Roth
Principal Product Manager

Daniel Roth is a Program Manager on the ASP.NET team at Microsoft.

164 comments

Discussion is closed. Login to edit/delete existing comments.

  • Andrei Lazarescu

    Hello Daniel,

    I am building an Blazor WebAssembly Hosted Identity application and I can not find one sample that is not using the Auth.UI. In my app I have Register and SignIn pages that make request via an unauthorized http client to an account api controller that has the SignInManager and so on. On login the SignInManager signs in the user but on the client side it does not detect this. In the console I do...

    Read more
  • Bruno Blanes

    I know it is possible to debug C# code on running on the browser on Visual Studio since Preview 2 or 3, but is it possible to debug JavaScript code the same way? My break points are only being hit on Visual Studio if I first set them on the browser. That doesn’t happen with C# code.

  • Fabian

    Hi Daniel, great that you managed to integrate localisation and i18n into the first stable release of Blazor! But something strikes me about the actual situation: i18n is based on resx files and those are only editable in Visual Studio and they only compile in Visual Studio. Thus, i18n is not supported in vs code. But vs code is such a charming IDE. I would love to know what are your plans for Blazor: are...

    Read more
  • Sergei Y.Kitáev

    Good day, Daniel!
    In continuation regarding to ASPNETCORE_ENVIRONMENT != Development:
    My errors now I see are: “Failed to load resource: the server responded with a status of 404 ()” —
    for “https://localhost:5001/_framework/blazor.boot.json” and for all “*.js” (in my client-server sample).

    But, official examples have work (I was thinking). Standalone console test (AspNetServer+Blazor) was working earlier in different variations and modes: Development / Production (with empty env.var.) / other. From now any environment which is not marked...

    Read more
    • Daniel RothMicrosoft employee Author

      Hi Sergei. This sounds like the same issue as https://github.com/dotnet/aspnetcore/issues/21992. I suspect the handling of the client static assets in a Blazor WebAssembly app is tied specifically to the Development environment, but we’ll follow up on the GitHub issue and then figure out the correct course of action.

      • Sergei Y.Kitáev

        Good day, Daniel!
        Thank you for this link.
        Indeed, Visual Studio simulates development environment unconditionally when it starts server process: Properties/launchSettings.json/"profiles"/"Blazor.Server"/"environmentVariables"/"ASPNETCORE_ENVIRONMENT": "Development".
        (All is exacly as they say.)
        But, “.StaticWebAssets.xml” is new form of server-to-client referencing.
        (The previous was “.blazor.config”.)
        Thanks!

        === July 15, 2020: ===
        Client-Server WASM-application in C#, TypeScript and T-SQL

        Good day, Daniel!
        Good day for everyone!

        I would like to represent my experimental work which is related to Blazor-WASM (and not only).
        The name...

        Read more
      • Sergei Y.Kitáev

        Good day, Daniel!
        It is possible to use following trick for the sake of development static assets (while they do like so dev.environment):

        <code>

        I wonder, why don't you still use “Nullable: enable” in official “.csproj”?

        Read more
  • Shawn Shaddock

    Is Blazor WebAssembly 3.2.0 still using mono?

    • Daniel RothMicrosoft employee Author

      Hi Shawn. Blazor WebAssembly is based on a .NET IL interpreter implemented in WebAssembly. The base class libraries are currently from Mono, but we are switching to the .NET Core implementations for .NET 5.

      • Shawn Shaddock

        Will there be substantial performance improvements when it's switched to .NET 5? I'm using BigInteger in my application, but finding the performance problematic. In my specific case the BigInteger.ModPow method is taking 337x longer in blazor wasm then in a .NET Core console app.

        I submitted an issue to the mono team
        https://github.com/mono/mono/issues/19908

        But it would be nice to have some assurance that the performance will be much better once blazor goes live with .NET 5
        Thanks!

        Read more
  • Sergei Y.Kitáev

    Good day, Daniel!
    Here I continue my question about BLAZORHOSTED template: https://devblogs.microsoft.com/aspnet/blazor-webassembly-3-2-0-release-candidate-now-available/#comment-2338.
    Thank you for the response!
    Thank you very much for long-awaited release of WebAssembly!
    I do have .NET Core 3.1.4 installed and “dotnet --version” command returns 3.1.300 after installation of the SDK and adding path to “C:\Program Files\dotnet\sdk\3.1.300” folder (via Path-env.var.correction).
    Directly after installation of SDK 3.1.300 the only two Blazor templates are available: blazorwasm and blazorserver. (After executing “dotnet new -i Microsoft.AspNetCore.Blazor.Templates”...

    Read more
    • Daniel RothMicrosoft employee Author

      Hi Sergei.

      It sounds like you have the correct version of the .NET Core SDK installed (3.1.300), which includes the Blazor WebAssembly template. No need to separately install the template anymore.

      I. Any static files in the wwwroot folders of the client or server projects should be accessible to the Blazor client.

      II. The dependency from the server project to the client is not technically necessary, but it is used to the development experience much more smooth. If...

      Read more
      • Sergei Y.Kitáev

        Good day, Daniel!
        Thank you for explanation concerning strategy (DOM, JS-interop., binary dependency on client-side)!

        I still do have questions about strategy of Blazor. It could be interesting to know something about plans to future incarnations of Blazor and Razor.
        1) Will Blazor ever target desktop for building cross-platform UI, and against what markup language it is planned to do (HTML/CSS, XAML)?
        2) Is Blazor technology (or another similar approach) considered at least theoretically to be...

        Read more
      • Daniel RothMicrosoft employee Author

        Will Blazor ever target desktop for building cross-platform UI, and against what markup language it is planned to do (HTML/CSS, XAML)?

        Yes, this is a direction we are exploring with the Mobile Blazor Bindings, which uses Razor syntax to build native cross-platform UI. We are working on hybrid web model as well, which we hope to share soon. We hope to apply the learnings from these experiments to .NET MAUI in the .NET 6...

        Read more
      • Sergei Y.Kitáev

        Good day, Daniel!

        I’ve composed my binary independent client-server sample (quasi-independent).
        And it seems I can publish them, and even combine: C-Debug vs. S-Release or C-Release vs. S-Debug.
        But, could you help me once again with your answer?

        What may be supposed cause of following problem:

        All looks fine while ASPNETCORE_ENVIRONMENT=Development.

        1) When ASPNETCORE_ENVIRONMENT=DebugExpose (my special configuration) all includable “*.js” causes error: “Failed to load resource: net::ERR_CONNECTION_REFUSED”;

        2) When ASPNETCORE_ENVIRONMENT=
        The errors is “Failed to load resource: the server responded...

        Read more
  • Guru Vignesh

    Hi All,
    It's really excited to see the official web assembly version, I am thrilled and I just updated my existing project to 3.2 Version. To my surprise I read like TimeZone support is already there in preview 5 version. But still now If I try for DateTime.Now -> It is returning UTC Time only.

    Related Issue in GitHub is also marked as Closed:
    https://github.com/dotnet/aspnetcore/issues/15776

    Could any one please help me, Or Still the Issue needs to...

    Read more
    • Daniel RothMicrosoft employee Author

      Hi Guru. should reflect the local timezone of the browser. If it isn't, that may mean the timezone data wasn't loaded correctly. Could you please check that dotnet.timezones.dat is being download correct to the browser? Did you possibly turn off timezones support as described here? If everything seems setup correctly but timezones are still not working please open a GitHub issue and we'll take a look: https://github.com/dotnet/aspnetcore/issues.

      Read more
      • Tyler Richardson

        Hi Daniel,

        Sorry to hijack the thread but I’m experiencing the same issue as Guru. I followed your advice to no avail so I posted an issue on GitHub: https://github.com/dotnet/aspnetcore/issues/22544

  • Steven Pua

    Is there an existing prototype for aot blazor wasm? How was the performance gain for starting the app? My current setup using my laptop loads the basic template in 1-1.5 sec with cache. My phone loads it around 4 sec with cache.

  • Richard Hernandez

    Congrats Daniel,
    I'm loving Blazor WebAssembly, got CI/CD going from Github repo thru Azure Pipelines, sweet!

    Only one little issue, I can't seem to access Azure Application Settings. If I publish via Visual Studio including appsettings.json in wwwroot everythings works but with CI there is no appsettings.json in the repo. I'm sure I'm missing something in the program.cs, at the moment I inject IConfiguration into a service.

    Any thoughts?

    Read more
    • Daniel RothMicrosoft employee Author

      Hi Richard. I don't think there is a way to read Azure App Settings from Blazor WebAssembly. The Azure App Settings are stored in environment variables on the server or injected into a server-side .NET app through System.Configuration. There isn't a mechanism to flow these values to the browser. Instead, any configuration values that you want to flow to the browser need to be stored in appsettings.json so that they can be retrieved.

      Read more
  • vijaymohan v

    Congrats!. This is the day the internet takes one great leap forward.

    • Daniel RothMicrosoft employee Author

      Thank you! We hope you enjoy working with Blazor!

'; block.insertAdjacentElement('beforebegin', codeheader); let button = codeheader.querySelector('.copy-button'); button.addEventListener("click", async () => { let blockToCopy = block; await copyCode(blockToCopy, button); }); } }); async function copyCode(blockToCopy, button) { let code = blockToCopy.querySelector("code"); let text = ''; if (code) { text = code.innerText; } else { text = blockToCopy.innerText; } try { await navigator.clipboard.writeText(text); } catch (err) { console.error('Failed to copy:', err); } button.innerText = "Copied"; setTimeout(() => { button.innerHTML = '' + svgCodeIcon + ' Copy'; }, 1400); }