Angular est un framework JavaScript développé et maintenu par Google. Il permet de développer facilement des applications web en utilisant un ensemble d'outils harmonisés pour tirer le meilleur parti des technologies web. Angular et plus permet d'accélérer encore davantage la vitesse des développements.
JavaScript est un langage de programmation interprété, qui s'utilise généralement dans une application web (dans le navigateur). Il est souvent utilisé via des frameworks comme Angular, React ou VueJS.
Utilité (fonction)
Angular est utilisé pour construire des applications web dynamiques et interactives, en particulier les applications à page unique (SPA).
JavaScript est un langage de programmation principalement utilisé pour le développement web, permettant d'ajouter des fonctionnalités interactives aux pages web. Il est également utilisé pour le développement de serveurs (Node.js), d'applications mobiles (React Native), et de jeux.
Langue de programmation
TypeScript (JavaScript peut également être utilisé).
JavaScript est un langage de programmation (script) interprété, orienté objet et fonctionnel.
Système d‘exploitation
Multiplateforme (fonctionne sur n'importe quel système d'exploitation avec un navigateur web moderne).
JavaScript est multiplateforme, fonctionnant sur n'importe quel système d'exploitation doté d'un navigateur web ou d'un environnement d'exécution compatible (comme Node.js).
Existe depuis
Angular a été initialement publié en septembre 2016 (réécriture complète d'AngularJS, initialement publié en 2010).
JavaScript a été initialement publié en 1996 par Brendan Eich
Licence
MIT License.
JavaScript est sous licence MIT pour de nombreuses bibliothèques et frameworks, tandis que le langage lui-même est standardisé par l'ECMA (ECMA-262).
Développeur
Google et la communauté open source.
JavaScript a été développé à l'origine par Brendan Eich chez Netscape, et est maintenant maintenu par une large communauté de développeurs et d'organisations comme Mozilla, Google, et Microsoft.
Communauté
Grande communauté active avec de nombreux contributeurs, forums, conférences (ngConf, AngularConnect), groupes d'utilisateurs, et ressources en ligne.
JavaScript bénéficie d'une vaste communauté active de développeurs, avec de nombreux forums, conférences, groupes d'utilisateurs et ressources en ligne.
Performance générale
Très bonne, avec un rendu efficace grâce à l'optimisation des performances et au changement de détection rapide.
JavaScript offre de bonnes performances, surtout avec les moteurs modernes comme V8 (utilisé par Chrome et Node.js) et SpiderMonkey (utilisé par Firefox). Les performances peuvent varier selon l'implémentation et l'environnement. Néanmoins comme tout langage interprété, il est moins rapide que les langages semi-compilés comme JAVA et encore moins rapide que les langages compilés type C++.
Maintenabilité
Élevée, grâce à une architecture basée sur des composants réutilisables, une gestion claire de l'état, et des services bien définis.
La maintenabilité de JavaScript peut varier, mais elle est améliorée par l'utilisation de bonnes pratiques, de conventions de codage strictes, et de l'utilisation de TypeScript pour ajouter une typage statique.
Facilité d'apprentissage
Modérée, nécessite une courbe d'apprentissage pour maîtriser TypeScript et les concepts d'Angular ; de nombreuses ressources sont disponibles pour les débutants.
JavaScript est considéré comme relativement facile à apprendre pour les débutants en programmation, grâce à sa syntaxe flexible et à sa large adoption. Cependant, certaines de ses particularités peuvent être déroutantes pour les nouveaux développeurs.
Configuration
Utilise des fichiers TypeScript pour définir les composants, les modules et les services ; la configuration peut être automatisée avec Angular CLI.
JavaScript ne nécessite aucune configuration particulière pour être utilisé dans un navigateur web. Pour le développement côté serveur avec Node.js, l'installation de Node.js et npm (Node Package Manager) est nécessaire.
Documentation
Documentation exhaustive et officielle disponible sur le site angular.io, ainsi que de nombreux livres et tutoriels en ligne.
JavaScript dispose d'une documentation exhaustive et officielle (MDN Web Docs). De nombreux livres, tutoriels en ligne, cours et forums sont également disponibles pour les apprenants de tous niveaux.
Alternative
Alternatives incluent ReactJS, Vue.js, Svelte, et Ember.js.
Les alternatives à JavaScript incluent TypeScript, Dart, et CoffeeScript.
On l'aime pour
Sa structure bien définie, ses outils de développement robustes, son écosystème riche, et sa grande communauté. Parfait pour les projets de grande taille.
Sa flexibilité, son omniprésence sur le web, son vaste écosystème de bibliothèques et de frameworks, et sa forte communauté.
On le déteste pour
Peut être complexe pour les petits projets, nécessite une bonne compréhension de TypeScript et des concepts d'Angular.
Ses incohérences historiques, sa syntaxe parfois déroutante pour les débutants, et ses problèmes de performance dans certains cas.
Fréquence de mise à jour
Mises à jour régulières avec des versions mineures tous les six mois et des versions majeures environ tous les ans.
JavaScript est mis à jour régulièrement avec de nouvelles versions de l'ECMAScript standard publiées annuellement, apportant de nouvelles fonctionnalités et améliorations.
LTS
Oui, certaines versions ont un support à long terme (LTS). Mais relativement court, 12 mois.
JavaScript lui-même n'a pas de versions LTS, mais certains environnements d'exécution comme Node.js offrent des versions LTS avec un support à long terme.
Maturité
Mature, avec plusieurs années de développement et d'utilisation dans de nombreux projets en production.
JavaScript est un langage mature, avec plus de deux décennies de développement et d'utilisation dans des millions de projets à travers le monde. Sa stabilité et sa fiabilité sont largement reconnues dans l'industrie.
Moto et philosophie
"Make the web interactive" – Conçu pour ajouter des fonctionnalités interactives aux pages web.
Paradigme de programmation
Orienté objet, fonctionnel, déclaratif.
Orienté objet, fonctionnel, impératif, événementiel.
Maintenabilité des développements
Élevée, grâce à une syntaxe claire, des fonctionnalités modernes comme les coroutines, et une interopérabilité complète avec Java.
Variable, dépend des pratiques et des frameworks utilisés.
Sécurité
Très bonne, avec des fonctionnalités de sécurité intégrées comme la gestion des utilisateurs, des rôles et des connexions sécurisées.
Modérée, avec des vulnérabilités courantes comme les injections de script (XSS).
Performance des applications
Très bonne à l'exécution. Souvent long à compiler.
Bonne pour des applications web, avec des moteurs JavaScript performants comme V8.
Deggugabilité
Excellente, avec des outils de débogage intégrés dans les IDE modernes et la compatibilité avec les DevTools des navigateurs.
Bonne, avec des outils de débogage intégrés dans les navigateurs (Chrome DevTools, Firefox Developer Tools).
Ecosystème
Vaste, avec de nombreuses bibliothèques et frameworks compatibles, et des définitions de types disponibles pour la plupart des bibliothèques JavaScript populaires.
Vaste, avec des frameworks et bibliothèques comme React, Angular, Vue.js, et Node.js pour le développement serveur.
Prise en charge des génériques
Oui, avec une syntaxe bien définie pour les types paramétrés.
Non, JavaScript n'a pas de génériques.
Exceptions vérifiées
Non, TypeScript ne supporte que les exceptions non vérifiées.
Non, JavaScript ne supporte que les exceptions non vérifiées.
Polymorphisme
Oui, à travers l'héritage et les interfaces en TypeScript.
Oui, à travers l'héritage prototype et les classes (ES6).
Conçu pour
Développement de grandes applications JavaScript maintenables et robustes avec un typage statique optionnel.
Développement web interactif et dynamique.
Type de sécurité
Sécurité basée sur les bonnes pratiques de codage en TypeScript et la vérification de type à la compilation.
Sécurité basée sur le sandboxing du navigateur.
Interropérabilité
Très bonne.
Très bonne, avec de nombreuses APIs pour interagir avec d'autres technologies.
Arrays
Prise en charge des tableaux dynamiques et typés via TypeScript.
Prise en charge des tableaux dynamiques.
Prise en charge de la compilation conditionnelle.
Oui, via les directives de préprocesseur en TypeScript.
Non, JavaScript ne supporte pas directement la compilation conditionnelle.
Prise en charge de l'instruction Goto.
Non, TypeScript n'inclut pas l'instruction goto.
Non, JavaScript n'inclut pas l'instruction goto.
Structure et syndicats
Prise en charge des objets, des classes et des unions via TypeScript.
Prise en charge des objets, mais pas des structs ou unions.
Fait pour
Développement de grandes applications JavaScript maintenables et robustes avec un typage statique optionnel.
Développement d'applications web interactives.
Installation
Installation via NPM
Aucune installation nécessaire pour le développement côté client ; Node.js est nécessaire pour le développement côté serveur.
Support multi-plateforme
Oui, fonctionne sur n'importe quel système d'exploitation avec un compilateur TypeScript et un moteur JavaScript.
Oui, dans tous les navigateurs modernes et via Node.js pour le serveur.
IDE
Visual Studio Code, WebStorm, Sublime Text.
Visual Studio Code, WebStorm, Sublime Text.
Environnement d'exécution
Navigateur web avec moteur JavaScript, serveur Node.js pour le rendu côté serveur.
Moteurs JavaScript des navigateurs, Node.js pour le serveur.
Dépendance à la plate-forme
Indépendant, fonctionne sur de nombreux systèmes d'exploitation grâce à TypeScript et aux navigateurs modernes.
Indépendant côté client, dépendant de Node.js côté serveur.
Pointers
Non, TypeScript n'a pas de pointeurs.
Non, JavaScript n'a pas de pointeurs.
Point flottant
Oui, prise en charge du type number qui inclut les flottants en TypeScript.
Oui, prise en charge du type number qui inclut les flottants.
Indice TIOBE
Non applicable directement, mais TypeScript (utilisé avec Angular, ReactJS et autres) est de plus en plus populaire.
Généralement dans le top 10.
Mode d'Exécution du Langage
Semi-compilé. Le code source est transcompilé en JavaScript, puis exécuté par le moteur JavaScript.
Interprété. Le code source est exécuté directement par le moteur JavaScript du navigateur ou NodeJS.
Typage
Utilise un typage statique et fort. Les types sont déclarés dans le code et vérifiés à la compilation.
Utilise un typage dynamique et faible. Les types sont déterminés à l’exécution et les conversions implicites sont autorisées.
Entreprises célèbres utilisant
Google, Microsoft, IBM, PayPal.
Google, Facebook, Netflix