IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

  1. #1
    Chroniqueur Actualités

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mars 2013
    Messages
    8 853
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Mars 2013
    Messages : 8 853
    Points : 205 445
    Points
    205 445
    Par défaut State of JavaScript 2021 : React reste de loin le framework front-end le plus utilisé par les développeurs
    State of JavaScript 2021 : React reste de loin le framework front-end le plus utilisé par les développeurs,
    mais en termes de satisfaction il est éclipsé par Solid et Svelte

    Créé en 1995, JavaScript est aujourd'hui le langage le plus populaire selon de nombreux baromètres. C'est également l'écosystème dans lequel on voit le plus de technologies naitre tous les jours. Comme conséquence, il est parfois très difficile de faire des choix ou de voir une technologie s'imposer comme la norme à moins d'avoir de puissants sponsors pour la propulser. Selon les catégories, certaines technologies arrivent toutefois à se distinguer. C'est dans le but d'identifier clairement ces dernières qu'entre en jeu le State of JavaScript, une enquête annuelle internationale sur l'écosystème JavaScript.

    Les résultats de l'édition 2021 sont disponibles et nous présentons ici les points saillants.

    L'enquête State of JavaScript de 2020 est issu d'une enquête auprès de 23 000 développeurs. 2021 était le résultat d'un peu plus de 16 000. Et bien que les États-Unis soient en tête, leur part de répondants au sondage est tombée à 14 % et la Russie a grimpé à la troisième place derrière l'Allemagne avec 4 %. La France a produit 4,2 % des réponses de l'enquête, ce qui correspond à 668 développeurs JavaScript. D'ailleurs, les langues dans lesquelles les développeurs JavaScript ont répondu sont :
    1. l'anglais avec 70,1 % ;
    2. l'espagnol avec 5,4 % ;
    3. le russe avec 5 % ;
    4. le français avec 3,3 % ;
    5. l'allemand avec 2,3 %.

    Aperçu des utilisations

    Ce graphique présente les différents taux d'adoption pour chaque fonctionnalité, groupé par catégorie. La taille du cercle externe correspond au nombre total d'utilisateurs qui connaissent une fonctionnalité, alors que le celui interne représente ceux qui l'utilisent actuellement.

    Nom : un.png
Affichages : 123466
Taille : 148,9 Ko

    Langage

    Quel niveau de compétence dans le vocabulaire de JavaScript ?

    Les proxy : l'objet Proxy est utilisé afin de définir un comportement sur mesure pour certaines opérations fondamentales (par exemple, l'accès aux propriétés, les affectations, les énumérations, les appels de fonctions, etc.). En 2021, 26,1 % du panel a déclaré les avoir déjà utilisés, contre 22,4 % en 2020 et 17,4 % en 2019. 43,5 % du panel en a déjà entendu parler, contre 39,1 % en 2020 et 39,8 % en 2019.

    Promise.allSettled() : La méthode Promise.allSettled() renvoie une promesse qui est résolue une fois que l'ensemble des promesses de l'itérable passée en argument sont réussies ou rejetées. La valeur de résolution de cette promesse est un tableau d'objets dont chacun est le résultat de chaque promesse de l'itérable.

    Code JavaScript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    const promise1 = Promise.resolve(3);
    const promise2 = new Promise((resolve, reject) => setTimeout(reject, 100, 'foo'));
    const promises = [promise1, promise2];
     
    Promise.allSettled(promises).
      then((results) => results.forEach((result) => console.log(result.status)));
     
    // expected output:
    // "fulfilled"
    // "rejected"

    En 2021, 19 % du panel l'a déjà utilisé (contre 14 % en 2020) et 46,4 % du panel le connaît (contre 42,3 % en 2020).

    Fonctionnalités fournies par le navigateur

    Service workers : Les service workers jouent essentiellement le rôle de serveurs proxy placés entre une application web, et le navigateur ou le réseau (lorsque disponible.) Ils sont destinés (entre autres choses) à permettre la création d'expériences de navigation déconnectée efficaces, en interceptant les requêtes réseau et en effectuant des actions appropriées selon que le réseau est disponible et que des ressources mises à jour sont à disposition sur le serveur. Ils permettront aussi d'accéder aux APIs de notifications du serveur (push) et de synchronisation en arrière-plan.

    Un service worker est un worker événementiel enregistré auprès d'une origine et d'un chemin. Il prend la forme d'un fichier JavaScript qui peut contrôler la page ou le site web auquel il est associé, en interceptant et en modifiant la navigation et les requêtes de ressources, et en mettant en cache les ressources selon une granularité très fine pour vous donner une maîtrise complète de la manière dont doit se comporter votre application dans certaines situations (l'une des plus évidentes étant l'indisponibilité du réseau.)

    Un service worker fonctionne dans le contexte d'un worker : il n'a donc pas d'accès au DOM, et s'exécute dans une tâche différente de celle du script principal de votre application, ainsi il est non-bloquant. Il est conçu pour être totalement asynchrone ; en conséquence, des APIs telles que XHR en synchrone et localStorage ne peuvent pas être utilisées au sein d'un service worker.

    Les service workers fonctionnent uniquement sur HTTPS, pour des raisons de sécurité. Laisser des requêtes réseau modifiées sans défense face aux attaques de l'homme du milieu est une bien mauvaise chose.

    En 2021, 45,7 % du panel les ont déjà utilisés (contre 42 % en 2020 et 36,2 % en 2019) et 45,9 % en ont déjà entendu parler (contre 48,8 % en 2020 et 54,1 % en 2019).

    Nom : deux.png
Affichages : 8185
Taille : 30,4 Ko

    Intl : l'objet Intl est l'espace de noms pour l'API d'Internationalisation d'ECMAScript. Elle fournit des outils de comparaison de chaînes de caractères, de formatage des nombres, de dates et de l'heure selon les langues. Intl donne accès à plusieurs constructeurs et fonctionnalités communes aux constructeurs destinés à l'internationalisation et à d'autres fonctions dépendantes des langues.

    En 2021, 45,7 % du panel l'avaient déjà utilisé (contre 42 % en 2020) et 45,9 % en avaient déjà entendu parler (contre 48,8 % en 2020).

    Autres fonctionnalités

    Progressive Web App : les applications Web progressives utilisent des API Web modernes ainsi qu'une stratégie d'amélioration progressive traditionnelle pour créer des applications Web multiplateformes. Ces applications fonctionnent partout et fournissent quelques fonctionnalités qui donnent à l'expérience utilisateur les mêmes avantages que les applications natives. Pour qu'une application Web soit considérée comme un PWA, techniquement parlant, il devrait présenter les caractéristiques suivantes : Secure contexts (HTTPS), un ou plusieurs Service Workers et un fichier manifest.

    Nom : trois.png
Affichages : 8099
Taille : 29,1 Ko

    WebAssembly : WebAssembly est un nouveau type de code qui peut être exécuté dans un navigateur web moderne. C'est un langage bas niveau, semblable à l'assembleur permettant d'atteindre des performances proches des applications natives (par exemple écrites en C/C++) tout en fonctionnant sur le Web. WebAssembly est conçu pour fonctionner en lien avec JavaScript.

    WebAssembly permet d'exécuter du code (éventuellement écrit depuis différents langages) sur le Web avec des performances similaires aux applications natives. WebAssembly est conçu pour être utilisé de pair avec JavaScript. Grâce à l'API JavaScript WebAssembly, on peut charger des modules WebAssembly au sein d'une application JavaScript et partager des fonctionnalités entre les deux. Cela permet de tirer parti des performances de WebAssembly et de la flexibilité de JavaScript, même si on ne sait pas écrire du code WebAssembly.

    Nom : quatre.png
Affichages : 8109
Taille : 28,9 Ko

    Bibliothèques et frameworks

    Frameworks front-end

    En termes de frameworks front-end, React a continué à être en tête des outils les plus utilisés, suivi par Angular et Vue.js. React est également en tête des classements de notoriété, mais sa baisse de satisfaction est marquée, la bibliothèque se classant désormais à la troisième place alors que l'intérêt diminuait, plaçant React quatrième derrière Vue.js, Solid et Svelte. Solid est arrivé en tête pour la satisfaction et en deuxième pour l'intérêt, même s'il était deuxième en partant du bas en termes de personnes l'utilisant réellement (derrière Alpine.js et Ember).

    Nom : cinq.png
Affichages : 8280
Taille : 128,5 Ko

    Frameworks back-end

    Côté frameworks back-end, Sveltekit est en tête en matière de satisfaction, suivi par Astro, Fastify, Next.js et Remix. En termes d'utilisation, c'est plutôt Express qui conserve la tête du classement, suivi par Next.js, Gatsby et Nuxt.

    Nom : six.png
Affichages : 8129
Taille : 35,5 Ko

    Frameworks de test JavaScript les plus populaires

    Comment les développeurs JavaScript testent-ils leurs applications ? Jest est l'outil le plus utilisé, suivi de Mocha, Storybook, Cypress et Jasmine. Concernant la satisfaction, Testing Library obtient la première place, suivi de Vitest et Jest.

    Nom : sept.png
Affichages : 8432
Taille : 41,4 Ko

    Mobile et desktop

    Concernant l'utilisation, les développeurs JavaScript se servent plus d'Electron, React Native, Cordova et Ionic. En matière de satisfaction, Tauri, Capacitor et Electron forment respectivement le trio de tête.

    Nom : huit.png
Affichages : 8099
Taille : 39,4 Ko

    La majorité des répondants pensent que le langage « évolue dans la bonne direction » et il y a eu une légère baisse de la proportion qui a estimé que la création d'applications était trop complexe.

    Quant à ce qui manquait, le typage statique est resté en tête des classements, même si une majorité de répondants se sont déclarés « satisfaits » ou « très satisfaits » de l'état général de JavaScript et des technologies Web en général. 22 % de ceux qui ont répondu à la question sur le salaire ont indiqué qu'ils sont payés de 100 000 $ à 200 000 $ par an.

    Shawn Wang, Head of DX chez Temporal, a fait le commentaire suivant :

    « JavaScript est dans un état extrêmement meilleur aujourd'hui par rapport à 2016.

    « À l'époque où la première enquête sur l'état de JS a eu lieu, seuls 21 % d'entre vous utilisaient TypeScript, contre 69 % aujourd'hui. Alors que nous avions l'habitude de plaisanter sur un nouveau framework front-end publié chaque jour, React et Vue dominent maintenant depuis 6 ans. Et le pourcentage de personnes déclarant que "JS va trop vite" est passé de 59 % à 38 %.

    « Cela ne veut pas dire que le langage s'est arrêté. Les API de chaînage facultatif et de coalescence nulle sont devenues les nouvelles API les plus utilisées dans notre enquête, bien qu'elles n'aient que 2 ans. Et d'autres bonnes choses sont en route depuis TC39 : vous avez signalé que la gestion des dates est une fonctionnalité manquante, et l'API Temporal a récemment atteint l'étape 3.

    « L'écosystème de l'outillage connaît également sa propre évolution rapide, et il est juste de dire que 2021 a été l'année de Vite. Vite a non seulement fait ses débuts avec un taux de satisfaction de 98 %, mais son utilisation est déjà à 30 % au cours de sa première année sur notre enquête, éclipsant même esbuild. Vite n'est pas le seul à essayer d'améliorer l'état des outils de construction JavaScript - 8 des 12 outils que nous suivons aujourd'hui ont moins de deux ans ! Et tandis que pnpm, Turborepo et Nx ont pris les premières places lors de notre première année de suivi de l'outillage monorepo, seuls 25 % déclarent être satisfaits de l'état de cette catégorie, ce qui montre qu'il reste beaucoup de travail à faire.

    « À noter également : de nombreux nouveaux entrants comme Deno, Rome, Astro, Remix, etc. sont désormais soutenus par des entreprises soutenues par du capital-risque, constituant peut-être une alternative viable au fragile environnement de financement open source.

    « Alors que le troisième âge de JavaScript entre dans sa troisième année, les opportunités pour les aspirants entrepreneurs et entrepreneurs open source continuent de se déployer, et j'ai hâte de voir ce que les deux prochaines années apporteront ! »

    Source : résultats de l'enquête

    Que pensez-vous des conclusions de cette enquête ?
    Utilisez-vous ou avez-vous déjà utilisé des déclinaisons de JavaScript ? Si oui, lesquelles ? Quelles sont vos impressions ?
    Selon vous, quelles fonctionnalités manquent encore à JavaScript ?
    Quelles technologies JavaScript utilisez-vous le plus (frameworks, test, développement mobile et desktop, etc.) ?

  2. #2
    Membre chevronné Avatar de Mister Nono
    Homme Profil pro
    Ingénieur Mathématiques et Informatique
    Inscrit en
    Septembre 2002
    Messages
    2 234
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur Mathématiques et Informatique
    Secteur : Santé

    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 234
    Points : 1 897
    Points
    1 897
    Par défaut
    JS c'est de la daube.

    Ce n'est pas pour rien que de très bons frameworks comme Angular sont plébiscités.

  3. #3
    Membre éprouvé

    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    506
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2009
    Messages : 506
    Points : 1 291
    Points
    1 291
    Par défaut
    React est le framework utilisé par tout le monde (dont moi) alors que solid et svelte (que je connais aussi) sont "choisis".
    Donc tout à fait normal que le taux de satisfaction des utilisateurs solid et svelte soit supérieur, ça ne veut rien dire sur la qualité du framework lui même

  4. #4
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 692
    Points : 20 241
    Points
    20 241
    Par défaut
    Le monde des frameworks commencent à se stabiliser c'est pas plus mal !

    React ou vue sont très bien pour ceux qui font beaucoup de front notamment grace à leur approche qui est assez similaire a ce qu'on faisait "avant" en mixant html et js dans les même fichiers.
    Perso comme je fais l'aller retour en permanence entre front/back/mobile natif , je préfère Angular qui une philosophie bien plus proche de ce que je fais ailleurs en PHP,C++ ou Java.

    Par contre l'ecosystème est toujours trop compliqué à mon gout quand on ne passe pas par un framework qui gère tout.
    Il manque un standard unique , simple à mettre en place.

    Si on veux un truc un peu industrialisé avec tests unitaires, serveur de dev, typescript , build de release c'est vite une galère sans nom à mettre en place.

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2022
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Santé

    Informations forums :
    Inscription : Février 2022
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Next.js ou Nest.js ?
    Next.js est plutôt un framework Front-end non ? Vous avez pas confondu avec NestJs pour le framework back-end ?

  6. #6
    Membre chevronné Avatar de Mister Nono
    Homme Profil pro
    Ingénieur Mathématiques et Informatique
    Inscrit en
    Septembre 2002
    Messages
    2 234
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur Mathématiques et Informatique
    Secteur : Santé

    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 234
    Points : 1 897
    Points
    1 897
    Par défaut
    Citation Envoyé par Shynryu Voir le message
    Next.js est plutôt un framework Front-end non ? Vous avez pas confondu avec NestJs pour le framework back-end ?
    Ha bon ? Ce n'est pas Nestlé ?

  7. #7
    Membre régulier
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 108
    Points : 80
    Points
    80
    Par défaut
    Si on veux un truc un peu industrialisé avec tests unitaires, serveur de dev, typescript , build de release c'est vite une galère sans nom à mettre en place.
    en React (et pour Vue également, sûrement pour Angular aussi) le bundler Vite (https://vitejs.dev/) facilite bien les choses en prenant nativement en compte TS. Il est également beeeaucoup rapide que Webpack utilisé par CRA.

    Après pour le reste quelques libs font le café :
    • jest pour les TU
    • prettier / eslint pour les conventions de code
    • semantic-release / husky pour la validation


    Voir partir sur du Nuxt / Next

  8. #8
    Membre régulier
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 108
    Points : 80
    Points
    80
    Par défaut
    Citation Envoyé par Shynryu Voir le message
    Next.js est plutôt un framework Front-end non ? Vous avez pas confondu avec NestJs pour le framework back-end ?
    Next.js => front
    NestJS => back

Discussions similaires

  1. Réponses: 0
    Dernier message: 17/01/2022, 15h50
  2. Réponses: 10
    Dernier message: 10/02/2021, 15h03
  3. JavaScript, Python et Java sont les langages de développement les plus utilisés par les développeurs
    Par Stéphane le calme dans le forum Débats sur le développement - Le Best Of
    Réponses: 0
    Dernier message: 22/10/2020, 17h39
  4. [VueJS vs Angular vs React] Comment choisir le bon framework javascript en 2018?
    Par pterrat dans le forum Bibliothèques & Frameworks
    Réponses: 0
    Dernier message: 08/06/2018, 10h35
  5. Réponses: 6
    Dernier message: 01/10/2016, 00h32

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo