Fut un temps, il suffisait aux développeurs front-end de connaître un peu de HTML, de CSS et peut-être de jQuery pour créer des sites web interactifs. Aujourd'hui, ils sont confrontés à un vaste écosystème en constante évolution de compétences à développer, d'outils, de bibliothèques et de frameworks à maîtriser.
Ces dernières années, sont apparus de nouvelles bibliothèques et de nouveaux frameworks, comme React.js, Vue.js et Svelte, qui utilisent JavaScript pour alimenter les principales applications web.
Voici quelques tips sur les tendances front end en 2021, que tu commences juste à programmer ou que tu aies déjà une certaine expérience.
Générateurs de sites statiques
Les générateurs de sites statiques combinent à la fois la puissance du rendu côté serveur et les applications à page unique.
De nombreux projets choisissent un SSG même s'ils n'ont pas besoin d'un rendu côté serveur car des solutions comme Next ou Nuxt sont dotées de fonctionnalités pratiques, telles que le support de la démarque, les modules de regroupement, les testeurs intégrés, etc.
PWA
De plus en plus de sociétés préfèrent les PWA aux applications natives pour offrir à leurs utilisateurs des expériences mobiles riches.
Les PWA sont fiables (chargement instantané, fonctionnement sans connexion Internet), rapides (animations fluides, réponses rapides à l'interaction de l'utilisateur) et attrayantes (sensation d'application native, expérience utilisateur exceptionnelle).
Frameworks
Ils font appel à des travailleurs de service pour les fonctionnalités hors ligne et à un fichier manifeste d'application web pour une expérience en plein écran.
Les développeurs frontend travaillant ou souhaitant travailler avec des frameworks JavaScript devraient se concentrer sur React et Vue comme leurs choix principaux. Angular est une option valable si vous travaillez sur des projets de grande envergure.
JAMstack
JAMstack est un moyen de créer des sites web et des applications plus performants, avec des coûts de mise à l'échelle réduits, une sécurité accrue et une meilleure expérience pour le développeur.
Bien que ces termes ne soient pas nouveaux en soi, ils ont tous un point commun : ils ne dépendent pas d'un serveur web. Ainsi, une application monolithique qui s'appuie sur un backend Ruby ou Node.js ou un site construit avec un CMS côté serveur comme Drupal ou WordPress n'est pas construit avec le JAMstack.
Il existe quelques bonnes pratiques si tu souhaites travailler avec le JAMstack :
- Projet entier servi sur un CDN : Comme aucun serveur n'est nécessaire, l'ensemble du projet peut être servi à partir d'un CDN, ce qui permet de débloquer une vitesse et des performances inégalables.
- Constructions automatisées : Vous pouvez automatiser les constructions à la perfection car tous les balisages sont pré-construits, par exemple avec des webhooks ou des services de cloud computing.
- Atomic déploie : Afin d'éviter les états incohérents en redéployant des centaines ou des milliers de fichiers dans les grands projets, les déploiements atomiques attendent que tous les fichiers soient téléchargés avant que les changements soient mis en ligne.
- Invalidation instantanée du cache : Lorsqu'un site est mis en ligne, vous devez vous assurer que votre CDN peut gérer des purges de cache instantanées pour que les changements deviennent visibles.
Des hébergeurs bien connus, comme Netlify ou Zeit, prennent en charge les applications JAMstack.
GraphQL
Alors que REST a longtemps été considéré comme la norme de facto pour la conception d'API web en offrant de grands concepts comme les serveurs apatrides, les API RESTful sont de plus en plus considérées comme inflexibles lorsqu'il s'agit de suivre l'évolution rapide des clients qui y accèdent.
Avec les API REST, les développeurs collectent des données en les récupérant à partir de plusieurs terminaux créés dans un but précis.
En utilisant GraphQL, les développeurs enverraient une requête à un serveur GraphQL avec leurs besoins en données. Le serveur renverrait alors un objet JSON avec toutes les données correspondantes.
Un autre avantage de GraphQL est qu'il utilise un système de caractères forts. Tout sur le serveur GraphQL est défini par un schéma utilisant le langage de définition de schéma (SDL) de GraphQL. Une fois que le schéma a été créé, les développeurs front et back peuvent travailler de manière assez indépendante les uns des autres car ils connaissent la structure de données définie.
Éditeurs de codes/IDE
Le code VS de Microsoft sera le numéro un des éditeurs pour la plupart des ingénieurs front en 2021.
Il offre des fonctionnalités presque similaires à celles de l'IDE, comme la complétion et la mise en évidence du code, et peut être étendu presque à l'infini grâce à son marché d'extensions.
Git
Git est sans aucun doute, la norme pour le contrôle de version dans le développement web de nos jours. Il est vraiment important pour tout ingénieur en amont de connaître les concepts de base de Git et les flux de travail pour travailler efficacement dans des équipes de toutes tailles.
Voici quelques commandes Git populaires que tu devrais connaître :
- git config
- git init
- clone de git
- statut de l'entreprise
- ajouter
- s'engager
- Poussez
- l'attraction
- branche git
Tester
Aucun code non testé ne devrait être mis en production.
Bien qu'il puisse sembler pratique de ne pas avoir de tests dans vos projets personnels, il est obligatoire d'en avoir lorsque vous travaillez dans des environnements d'entreprise. Il est donc préférable pour tout développeur d'intégrer des tests dans le flux de développement chaque fois que cela est possible.
Voici les différentes typologies de tests :
- Tests unitaires
- Tester un composant ou une fonction unique de manière isolée.
- Tests d'intégration
- Tester les interactions entre les composants.
- Test de bout en bout
- Test des flux d'utilisateurs dans le navigateur.
Il existe d'autres moyens de tester, tels que les tests manuels, les tests instantanés, etc.
Un code propre
Le code propre doit être agréable à lire, ciblé et tu dois en prendre soin. Tous les tests sont effectués en code propre. Ils ne doivent pas contenir de doublons, et l'utilisation d'entités, telles que des classes, des méthodes et des fonctions, doit être réduite au minimum.
Compétences non techniques : les soft skills
Souvent négligée mais vraiment, vraiment importante pour les développeurs est l'acquisition de compétences non techniques.
Si cela aide à comprendre l'aspect technique des choses, il est tout aussi important de savoir comment communiquer au sein d'une équipe !