VT2020-Blazor-Fiche
Blazor est un framework Web gratuit et open-source qui a été créé par Microsoft en 2018. Il permet aux développeurs de créer des applications Web avec une interface utilisateur Web interactive en utilisant C# et .NET.
Abstract
«Blazor lets you build interactive web UIs using C# instead of JavaScript. Blazor apps are composed of reusable web UI components implemented using C#, HTML, and CSS. Both client and server code is written in C#, allowing you to share code and libraries. Blazor is a feature of ASP.NET, the popular web development framework that extends the .NET developer platform with tools and libraries for building web apps.» - Documentation officielle de Blazor
Présentation
Blazor est un framework Web gratuit et open-source qui a été créé par Microsoft en 2018. Le but étant de faciliter l'implémentation des applications web, cette nouvelle infrastructure permet aux développeurs d’implémenter une interface utilisateur Web interactive côté client en utilisant C# avec .NET . Les applications Blazor sont composées de composants UI réutilisables implémentés à l'aide de C #, HTML et CSS. De ce fait, le code du client et du serveur (Frontend & Backend) est écrit en C#, ce qui nous permet de partager, facilement, du code et des bibliothèques dans les deux sens.
Origine du nom
Le nom Blazor est une combinaison des mots Browser ( Navigateur ) et Razor (la une syntaxe qui combine le balisage HTML avec du code C#). L'implication étant qu'au lieu d'avoir à exécuter des vues Razor sur le serveur afin de présenter du HTML au navigateur, Blazor est capable d'exécuter ces vues sur le client.
Exemple
Cet exemple figurant sur la page d'accueil de la documentation de Blazor. Il montre comment implémenter un simple compteur en cliquant sur un button.
<h1>Blazor counter example</h1>
<p>count: @count</p>
<button class="btn btn-primary" @onclick="IncCount">Click to increment</button>
@code {
private int count = 0;
private void IncCount()
{
count++;
}
}
Nous remarquons que le code HTML se positionne en haut de la feuille, en contenant la variable C#. Ainsi, le code C# vient en bas.
Les différentes éditions Blazor
Microsoft a annoncé qu'elle prévoit de publier cinq différentes éditions de Blazor. Pourtant, il existe, actuellement, que les deux éditions Blazor Server et Blazor WebAssembly qui sont révélées (cf. La partie «Fonctionnement»).
Fonctionnement
Pour exécuter les applications Blazor, vous pouvez choisir d'exécuter votre code côté client soit sur le navigateur ou sur le serveur.
Si vous choisissez d'exécuter votre code frontal sur le navigateur, Blazor utilisera WebAssembly pour exécuter le runtime .NET dans le navigateur. Sinon, si vous choisissez de l'exécuter du côté serveur, une application est déployée sur le frontend en se connectant à votre serveur via une connexion de socket Web SignalR.
Blazor WebAssembly
Blazor WebAssembly est une version qui exécute du code C# directement depuis le navigateur web une SPA(Single Page) classique tel que React, Angular, ... Comme son nom l'indique, Blazor WebAssembly est basé sur le nouveau standard WebAssembly.
Comme nous le voyans sur le schéma, le navigateur fourni le noyau du support WebAssembly. En dessus, il y a le .Net runtime qui est créé. Ensuite, nous pouvons créer nos composants du code Balzor. Une fois le code compilés en des assemblements .NET, les fichiers sont générer pour accéder au DOM et le rendu de notre application est fait.
Blazor Server
Cette version de Blazor est basé sur la bibliothèques de Microsoft ASP.NET, qui permet au code serveur d'envoyer des notifications asynchrones aux applications web côté client.
Avec la possibilité de partage de code entre ces deux versions, nous pouvons utiliser le même code que celui du Blazor WebAssembly. Alors, le navigateur envoie tous les évenements de l'interface utilisateur au serveur, surlequel le DOM virtuel est calculé. Le signalR se charge , enfin, de renvoyer au client, les modifications du DOM à effectuer.
Avantages
En général, Blazor a connu son succès car il permet de développer et d'exécuter des applications basées sur un navigateur en utilisant C#. Au cours des dernières années, JavaScript (ou TypeScript) a été le principal langage de programmation utilisé pour créer l'interface. Avec Blazor, tout développeur peut développer son application des côtés serveur et client en utilisant C# sans vraiment être obligé à apprendre, profondemment, Javascript.
Contrairement à JavaScript, Blazor est pré-compilé en langage intermédiaire. Cette fonctionnalité nous offre des avantages remarquables en ce qui concerne les applications exigeantes en termes de performances qui s'exécutent sur le navigateur. De plus, les applications Blazor peuvent fonctionner hors ligne pendant les périodes où plus de puissance de traitement est nécessaire, comme la génération de PDF, les algorithmes de jeu, etc.
En dehors de ceux-ci, il existe de nombreuses fonctionnalités de Blazor qui le rendent plus avantageux. Blazor :
- Ne nécessite pas de plug-ins de navigateur.
- Active le débogage complet .NET.
- Utilise les dernières fonctionnalités du navigateur Web.
- A une compatibilité du navigateur (même pour les anciennes versions).
- Peut partager du code entre le client et le serveur.
Limites
Blazor WebAssembly :
- Nécessite la livraison de l'intégralité du runtime.
- Ne fonctionne pas avec les clients légers.
- A une capacité de débogage et utilisation des outils .NET limitée.
Blazor Server :
- Utilise plus de bande passante.
- A une évolutivité réduite.
- Un serveur .NET est requis pour l'héberger.
Démonstration
Une démonstration est disponible ici.
Bibliographie et références
<references />