Blazor WASM is amazing, build apps super fast

2/5/2024, 3:46:58 AM | by Tigrish | 1020 views
Story banner

Blazor is a web application framework that uses C# to manage the UI. It allows for sharing of the codebase enabling rapid application development. In this article we will dive into its core and my experience with it.

A refresher

Since the beginning of the “mature” web, javascript has been the king of browser scripting languages, the go-to for any serious site, it offers DOM manipulation and enables reactivity on otherwise static HTML, and great apps have been made with it (Did you know Github doesn’t use a framework). Unfortunately, javascript was not properly designed, if at all, it was hacked together in a short period of time and we can feel the effects of it today with inconsistent APIs, multiple null types, and lack of proper types.

Typescript, created by Microsoft, aimed to fix it, but that is merely putting a band-aid on a big leak. There is only compile-time type safety, no JSON validation, and node_modules is filled with thousands of tiny files that need not exist.

Now this is not to say that the JS runtime is not effective at doing its job, on the contrary, it excels at manipulating the DOM to update the UI and fetching data from a server, but it is my strong belief that it should not be used in the backend, and it is by no means performant compared to Java, C#, Rust and C++ (which you should use sparingly).

A new way of running code from browsers was created that complements (and could eventually replace) the JS runtime, Webassembly. It is a VM that runs “web native” instructions, which executes magnitudes faster than JS in some cases.

Now comes Microsoft again, with a revolutionary new idea, this time, bring a compiled language with proper type safety into the browser and let it render the UI (mostly) without Javascript. (the language is C#).

What Blazor WASM is not

Web frameworks like Next, Nuxt, SvelteKit are built with SEO in mind, but the SPA client-side only nature of Blazor WASM (another article on Blazor Server coming soon) means it will be very hard to index pages reliably. Another downside is the initial bundle size of the app, which can range from 800 KB to 5 MB for a blank app, depending on the compilation mode (dynamic code vs statically compiled). Note that the app is only downloaded once.

I wouldn’t recommend Blazor as a website, but rather a “web app”, which is what it is, an app running in the browser.

Why I love it so much

I started coding as a C# developer using WinForms about 5 years ago, and I fell in love with it (obviously not the WinForms part). The language provides amazing type safety, error messages and handling, good separation of concerns, complete standard library, seamless tooling, and generally packed with more features than you would ever want or need. May I also note that it is open source. Well, now it can run in the browser so we can distribute apps directly via the browser to our clients, amazing isn’t it?

Blazor WASM offers a good package, as it features dependency injection, HTML templating via C# statements, CSS class templating, the entire class library of the .NET runtime, and if need be, javascript/typescript interop.

I code all my web APIs in ASP.NET C#, and that means I have tons of models, validators and helper methods as part of the backend. Now, what if I could offload part of the work to the client without writing a single line of Javascript? Well, the subject of this article is a perfect fit for this use case, you can simply move your C# code in a class library and use it in both the client and server. Transferring data has also never been easier, you can transmit JSON over HTTP or use gRPC or even SignalR, which all provide C#/.NET libraries that run in the browser via WASM.

Developer experience is very important, and sometimes JS frameworks give you cryptic error messages that will take you quite a while to debug and fix, but the error handling of the .NET runtime is amazing, you can diagnose and fix bugs in record time.

Blazor is also supported in mobile and desktop native apps via MAUI, but that is for another time.

Should I use Blazor WASM for my next project?

Well, as with most things in life, it depends! Say, is your app for existing business clients or for getting users via search engine listings? If the former, it is an amazing choice and I would recommend it any day, but if the latter, it may be worth considering other strategies, such as using an SSR framework (Nuxt is a favorite of mine). An admin panel, internal management tool or data visualizers are also good fits for Blazor.

Well, even if you don’t need to use this framework, I still highly recommend trying it out and making your own opinion out of it.

I will have more articles coming soon showcasing the power of Blazor.

Thanks for reading! Have a nice day or evening 🙂

The role of technology has evolved so much in sports, and especially in MMA.

Technology is changing the way we live, and this is even having an impact on MMA fights. Technology can be used to confirm or tarnish a fighter's career. Discover that with the Cédric Doumbé story's.

Product image
Is GTA 6 coming out in 2025? What the latest leaks tell us ?

stirring up the impatience of players and fueling the wildest rumors. In 2025, will the wait finally be rewarded? The date is becoming clearer thanks to certain financial indicators from the Rockstar Games’ parent CO.

Product image
The DT 770 pro is still top value in 2024

The Beyerdynamic DT 770 PRO have been around for so long and still provide very good value if you can get them at the right price. These are my personal thoughts after using them for over a year.

Product image
WARNO, overview of a super fun military strategy game

WARNO is a realistic cold war gone hot RTS which takes place in the 90s. Create your army and deploy it on the battlefield in casual 10v10 or competitive 1v1. It's insanely fun. Read more for the review.

Product image
With the season 2 release, has Call of Duty MODERN WARFARE 3 lived up to our expectations?

Activision's recent decisions regarding CALL OF DUTY have taken the game in directions that have sometimes been poorly received by the community. Is MODERN WARFARE 3 good at the moment?

Product image
Why AMD cards provide better value for gamers

High-end gaming as been a luxury lately and we try to give you the best suggestions to achieve amazing performance in games for good prices. AMD vs NVidia have close competition in the mid-range and we dive into it.

Product image
Smaller clouds provide outstanding value

Finding the perfect cloud can be tricky, and if you make the wrong choice: very expensive! Read more about our take on the major cloud providers and how to avoid falling down an unfortunate pit.

Product image
Tekken 8: The most epic fighting game ever.

TEKKEN 8 The long awaited fighting game that will make you unleash your inner rage.

Product image
The omnirole nature of C# and why it’s a top language

C# has enabled multitudes of performant and reliable applications to run for decades. A mature ecosystem, a huge class library and fun to write syntax make it a solid contender for the top league.

Product image
Hire us to make your next app or website!

At Entity Systems we strive to bring you the best quality, fastest and most reliable software. From websites to mobile and desktop apps, all is possible. Read a bit more about us in this post!

Product image
We need you to accept cookiesOur site works thanks to these, but we require your permission. We promise they are organic, vegan and gluten free.