Depuis que le HTML5 est devenu populaire, l'ensemble de la plateforme Web a fait de grands progrès et les gens ont commencé à considérer le JavaScript comme un langage capable de créer des applications complexes. De nombreuses nouvelles API ont vu le jour et des articles ont été rédigés sur la manière dont les navigateurs utilisent ces technologies.
En tant que langage de script, JavaScript a été créé à l'origine pour améliorer les performances des pages Web, mais JavaScript est désormais utilisé dans presque tous les endroits auxquels vous pouvez penser. À mesure que les capacités techniques de l’ensemble du secteur continuent de s’améliorer, JavaScript peut désormais s’exécuter côté serveur et peut également être compilé en code pour des applications mobiles natives. Les développeurs JavaScript d'aujourd'hui font partie d'un écosystème riche, avec des centaines d'IDE, d'outils et de frameworks à leur disposition. Avec le grand nombre d'options et de ressources disponibles, certains développeurs peuvent également avoir l'impression de ne pas savoir par où commencer. J'aimerais discuter et décrire la situation à laquelle sont confrontés les développeurs JavaScript modernes, en commençant par un bref historique de JavaScript, puis en couvrant certains des frameworks, outils et IDE les plus populaires aujourd'hui.
Faisons un petit voyage. En 1995, Netscape Navigator et Internet Explorer 1.0 étaient les seules options de navigateur. Le site est rempli de texte clignotant ennuyeux et de trop de GIF. Le chargement d'une page contenant beaucoup de contenu riche sur un réseau commuté peut prendre jusqu'à deux minutes complètes. Puis un langage Web est apparu qui permettait à ces anciens sites Web d’exécuter du code côté client. C'est l'année de naissance de JavaScript.
Ces sites web créés il y a 20 ans n'utilisaient pas beaucoup JavaScript, et n'exploitaient certainement pas tout le potentiel de ce langage. Parfois, il vous indiquera certaines informations via une boîte de dialogue contextuelle, ou affichera des actualités en faisant défiler le texte dans une certaine zone, ou utilisera un cookie pour enregistrer votre nom d'utilisateur afin que lorsque vous en passez plusieurs lors de votre visite ce site dans quelques mois, votre nom sera affiché directement. Bien sûr, aucun poste sur le lieu de travail n'utilisait JavaScript comme principal langage de développement. J'ai eu beaucoup de chance de pouvoir réellement écrire du JavaScript au travail. Bref, l’application de JavaScript sur les sites web à cette époque devait jouer quelques tours au DOM.
De nos jours, vous pouvez voir JavaScript partout. De Bootstrap à ReactJS, Angular, le jQuery universel, et même Node.js exécuté côté serveur, JavaScript est devenu le le plus populaire L'un des langages Web les plus importants et les plus populaires.
L'un des changements les plus importants apportés à JavaScript depuis sa création est la façon dont il est utilisé. Il est révolu le temps où il fallait appeler ces méthodes document.GetElementById délicates et créer des objets XmlHttpRequest encombrants. Au lieu de cela, ces fonctions de base sont résumées via diverses bibliothèques de classes utiles, rendant JavaScript plus facile à utiliser pour les développeurs. C’est l’une des principales raisons pour lesquelles JavaScript est partout aujourd’hui.
jQuery a été lancé par John Resig en 2006. Il fournit un riche ensemble d'outils qui résument et simplifient diverses commandes et méthodes JavaScript obscures et mystérieuses. Le moyen le plus simple de démontrer cet outil consiste à utiliser un exemple de code.
Créez une requête AJAX en utilisant du JavaScript pur :
function loadXMLDoc() { var xmlhttp; if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp = new XMLHttpRequest(); } else { // code for IE6, IE5 xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange = function() { if (xmlhttp.readyState == 4 ) { if(xmlhttp.status == 200){ alert("success"); } else if(xmlhttp.status == 400) { alert("error 400") } else { alert("something broke") } } } xmlhttp.open("GET", "test.html", true); xmlhttp.send(); }
Source : Stack Overflow
Utilisez jQuery pour créer des requêtes AJAX :
$.ajax({ url: "test.html", statusCode: { 200: function() { alert("success"); }, 400: function() { alert("error 400"); } }, error: function() { alert("something broke"); } });
jQuery rend les fonctions JavaScript complexes faciles à utiliser et les opérations DOM sont un jeu d'enfant. En conséquence, jQuery est devenu l'un des premiers frameworks JavaScript largement utilisés, et l'idée d'abstraire JavaScript est devenue la base de la construction de divers autres frameworks.
AngularJS, également connu sous le nom de « Augular », a fait ses débuts en 2009. Il s'agit d'un framework créé par Google pour simplifier la création d'applications à page unique (SPA). Semblable à jQuery, son objectif est de résumer des opérations complexes en méthodes hautement réutilisables. Il fournit une architecture modèle-vue-contrôleur (MVC) pour JavaScript.
ReactJS, également connu sous le nom de « React », est un petit nouveau dans le quartier. Il a été créé par Facebook et lancé pour la première fois en 2013. Facebook estime que React peut être une alternative à Angular pour gérer les problèmes de SPA, donc si vous pensez qu'Angular et React sont des concurrents, vous avez raison. Cependant, la plus grande différence entre React et Angular est qu'il s'agit d'une bibliothèque de classes plus efficace, plus performante et plus rapide. La figure ci-dessous montre le temps nécessaire pour restituer une liste de 1 000 éléments dans le DOM à l'aide de React, Angular, Knockout (une autre bibliothèque non abordée dans cet article) et de JavaScript pur :
Source : Le développeur Dapper
Si votre application est très performante, alors React est le bon choix.
Pour un développement efficace, l'utilisation de l'IDE est très importante. Le nom complet de l'IDE est environnement de développement intégré, qui est une application qui fournit aux développeurs une série d'outils. La partie la plus importante d'un tel outil est généralement un éditeur de texte riche , qui fournit généralement à l'utilisateur une coloration syntaxique, une saisie semi-automatique et des raccourcis clavier pour accélérer diverses tâches. opération.
Sublime Text n'est pas réellement un IDE, mais un éditeur de texte léger et rapide pour la programmation qui fournit une mise en évidence de la syntaxe et des raccourcis clavier intuitifs sont inclus. Il est intrinsèquement multiplateforme, il est donc idéal pour les développeurs qui souhaitent utiliser un Mac dans un environnement PC (ou vice versa). Presque toutes les parties de Sublime Text peuvent être personnalisées et il fournit également une variété de plug-ins qui lui ajoutent des fonctions de type IDE, telles que l'intégration avec Git et l'organisation du code. C'est un excellent choix pour les passionnés de JavaScript et les développeurs novices. Au moment de la publication, chaque licence Sublime Text coûte 70 $.
Source: Texte sublime
WebStorm est un IDE intelligent développé par l'équipe JetBrains, principalement axé sur le développement de HTML, CSS et JavaScript. Il facture des frais de licence nominaux (49 $ au moment de la publication de cet article), et il n'est pas déraisonnable qu'il soit largement reconnu parmi les experts JavaScript expérimentés et qu'il soit désormais considéré comme la norme de facto en raison de sa complétion et de sa révision de code intégrées. les outils sont uniques. Un débogueur JavaScript riche est également fourni dans WebStorm et est intégré à divers frameworks de tests unitaires populaires, tels que l'exécuteur de test Karma et JSDriver, et prend même en charge Node pour .js. L'une des meilleures fonctionnalités de WebStorm est sa fonction Live Edit. Tant qu'un plug-in est installé à la fois dans Chrome et WebStorm, les développeurs peuvent modifier le code et voir les résultats directement dans le navigateur. Les développeurs peuvent également configurer l'édition en direct pour mettre en évidence les modifications dans la fenêtre du navigateur, améliorant ainsi considérablement la productivité du débogage et du codage. Dans l'ensemble, si JavaScript est votre travail à temps plein, alors l'EDI WebStorm peut être un bon choix.
Source
:JetBrainsSupportsBrackets est un IDE gratuit open source axé sur les outils de visualisation. Brackets fournit une fonctionnalité d'édition en temps réel similaire à WebStorm, vous permettant de voir les résultats des modifications de code directement dans la fenêtre du navigateur. Il prend également en charge l'édition parallèle, vous permettant de travailler pendant le codage et de voir directement les résultats du code sans avoir à basculer entre différentes applications ou utiliser des fenêtres contextuelles. L'une des fonctionnalités les plus intéressantes de Brackets est appelée extraction (
Extractpour obtenir la police, la couleur, la taille et d'autres informations. Grâce à cette fonctionnalité, Brackets convient parfaitement aux développeurs JavaScript qui effectuent également des travaux de conception. (Cliquez sur l'image pour l'agrandir)
Source
: Supports Atom是由GitHub推出的一款开源的免费富文本编辑器,非常易于上手使用,在安装后可以直接运行,而无需进行任何配置文件的改动,就能够“良好地运行了”。Atom最有趣的一点是可以对它的每一方面都进行自定义(GitHub将其称为“可以随便折腾”),它是在一个web核心的基础上所创建的,因此用户就可以通过编写标准的HTML、CSS和JavaScript,对它的外观进行自定义。想要为Atom换个不同的背景和文本字体?改一下CSS就行。或者你也可以选择下载并应用各种为Atom所创建的主题。这种灵活性让Atom能够按照你所希望的方式进行展现。对于JavaScript新手开发者和热衷于自定义的用户来说,Atom是一个优秀的工具。 (单击图片以放大) 来源: Atom 现代的JavaScript项目正倾向于变得越来越复杂,变化的部分也在不断增多。这并不是说这门语言或是对应的工具不够高效,而是由于当前所创建的web应用程序的丰富性、酷炫的体验和复杂性所导致的直接后果。在大型的项目中工作时,你必须经常做许多重复性的工作,无论是在你打算签入代码、或是将代码构建到生产环境中。这些工作可能会包括合并、压缩、对LESS或SASS CSS文件的编译,甚至是运行测试。手动完成这些工作不仅令人沮丧,效率也很低下。更好的办法是通过某种支持这些任务的构建工具,对这些工作进行自动化。 你所编写的大多数JavaScript和CSS都会在多个web页面中共享。因此,你很可能会将这些内容放到单独的.js和.css文件中,然后在web页面中引用这些文件。这种方式的结果是,用户的浏览器为了完全显示你的web引用,需要分别发送一个HTTP请求,以获取这些文件(或者至少需要验证一下这些文件是否已经改变了)。 HTTP请求的代价是很高的。除了请求本身的大小之外,你还将因为网络延迟、HTTP头和Cookie等内容买单。合并与压缩工具的设计目的就是减少、乃至完全消除这些请求所带来的影响。 要改善web代码的性能,开发者所能做的最简单的一件事就是将代码进行合并。在合并流程中,多个JavaScript或CSS文件将被并入一个单一的JavaScript或CSS文件中。感觉上就像是将多张个别的全景图像的照片连接在一起,以完成一张继续的单一照片。通过将JavaScript文件与CSS文件进行合并,我们就能够消除很大一部分HTTP请求的开销。 JavaScript开发者还有一种可以改善性能的方式,就是将刚刚合并的代码进行压缩。压缩过程能够将JavaScript和CSS代码以尽可能最小的形式进行压缩,同时保证功能不变。对于JavaScript来说,这就意味着将变量重命名为无意义的单字符形式,并且去除所有空白和格式符。而对于CSS来说,由于页面风格依赖于变量的名称,因此通常来说只会去除格式符与空白。压缩能够极大的改进网络性能,因为它减少了每个HTTP响应的字节数。 未经压缩的AJAX JavaScript代码,与上面所展示的代码相同: 同样的代码经过压缩之后的形式: 请注意,我将压缩后的输出结果分为两行的目的,只是为了在文章中阅读起来更方便,而实际上经过压缩后的输出通常来说只有一行。 通常来说,合并与压缩步骤只会在生产环境上执行,这样做的原因是为了让你在本地或是开发环境中可以对包含了格式符和行号的原始代码进行调试。而调试上面所显示的那种压缩代码会非常困难,因为所有的代码都挤在一行中。而且压缩后的代码会变得完全不可读,在你尝试调试时会发现这种代码完全无用,并让你感到非常受挫。 有些时候,代码中的某些bug只有在生产环境才能重现。这样一来,当你要调试某些问题时,经过压缩的代码就成为了一个问题。幸运的是,JavaScript支持源代码映射文件,它能够在压缩后的代码和原始代码之间进行“映射”。这些代码映射文件是在压缩阶段由下文所说的某些构造工具所生成的。随后你的JavaScript调试器就能够使用这些映射文件,为你提供清晰可读的代码进行调试了。你应当尽可能将映射文件与实际代码一起发布,这样就能够在某些功能出错时进行代码的调试了。 代码整理工具会根据预定义的格式化规则检查你代码中的常见错误和问题,这些工具所报告的错误通常都类似于以下这些:使用了tab缩进而不是空格、在行末遗漏了分号、或是在没有使用if、for或while语句的情况下使用了大括号。大多数IDE中都提供了代码整理工具,而其它一些IDE也允许用户自行安装代码整理插件。 最流行的两种JavaScript整理工具是JSHint和JSLint,JSLint是由Doug Crockford开发的整理框架,而JSHint则是由社区人员从JSLint中分支出来的。他们仅在各自的代码格式化标准上有着一些区别。我的建议是两者都尝试一下,然后选择一个最适合你的代码风格的工具。 与它的名称不同,Grunt(本意为打呼噜)绝不是一个粗糙的工具,而是一个健壮的命令行构造工具,能够运行用户所定义的各种任务。通过设置一个简单的配置文件,你就可以让Grunt进行各种工作,例如编译LESS或SASS文件、构建并压缩某个特定文件夹中的所有JavaScript和CSS文件、甚至是运行某种代码整理工具或是测试框架。你也可以通过配置,将Grunt作为一种Git钩子运行,当你往源代码控制库里进行签入时,自动地压缩与合并你的代码。 Grunt支持各种命名的目标,因为你可以在不同的环境中指定不同的命令,比方说你可以将“dev”和“prod”指定为目标。这一点对于某些场景来说非常有用,例如在生产环境中将代码进行合并与压缩,而在开发环境中忽略这一步骤,以便于调试的需要。 Grunt中一个很有用的特性叫做“grunt watch”,它能够对一个目录中的文件,或一个文件集合中的变更进行监控。这一特性可以整合入WebStorm和Sublime Text这样的IDE中使用。通过使用监控特性,你可以根据文件变更的情况触发事件。对于LESS或SASS的编译就是这一特性的实用作法,你可以设置grunt以监控你的LESS或SASS文件,当文件产生变更时立即进行编译,编译后生成的文件就可以直接在开发环境中进行使用了。你也可以让grunt监控在你修改了每个文件之后都自动地运行某种代码整理工具。通过grunt监控进行实时任务执行,是一种加速你的生产力的极好的方式。 Grunt和Gulp都是用于解决构建自动化问题的工具,可以说两者是直接的竞争者。他们之间主要的差别在于,Grunt更专注于配置,而Gulp更专注于代码。你在Grunt文件中通过声明式的JSON对构建任务进行配置,而在Gulp文件中通过编写JavaScript函数以实现相同的功能。 下面的这个Grunt配置文件会在SASS文件产生变更时,编译生成CSS文件: 来源: Grunt vs Gulp – Beyond the Numbers 下面的这个Gulp配置文件同样会在SASS文件产生变更时,编译生成CSS文件: 来源: Grunt vs Gulp – Beyond the Numbers 我建议你可以随意选择自己所喜欢的那一种。这两种工具一般来说都是通过Node.js的包管理器npm下载的。 JavaScript自从互联网的早期诞生以来,已经经历了巨大的改进。如今,它已成为了交互式web应用程序中一个突出的重要组成部分。 开发者们从1995年起到如今也经历了巨大的变化,如今的开发者们更乐于使用丰富而健壮的框架、工具和IDE,以提高工作的效率和生产力。 Créer votre première application JavaScript moderne est peut-être plus facile que vous ne le pensez ! Choisissez simplement un IDE (je recommande Atom pour les débutants) et installez npm et grunt. Si vous êtes bloqué quelque part plus tard, Stack Overflow est une excellente ressource. Passez simplement un peu de temps à apprendre les bases et vous serez sur la bonne voie pour développer et finalement publier votre première application JavaScript moderne en un rien de temps. Framework : jQuery AngularJS ReactJS IDE : Sublime Text WebStorm Brackets Atom Outil d'organisation du code : JSLint JSHint Outils de construction et d'automatisation NPM Grunt Gulp Ressources pratiques Débordement de pile Les outils associés peuvent être téléchargés gratuitement à partir de la colonne outils de développement php du site Web chinois php ! Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!Atom
构建与自动化工具
合并(Bundling)与压缩(Minification)
合并
压缩
$.ajax({
url: "test.html",
statusCode: {
200: function() {
alert("success");
},
400: function() {
alert("error 400");
}
},
error: function() {
alert("something broke");
}
});
$.ajax({url:"test.html",statusCode:{200:function() {alert("success");},
400:function(){alert("error 400");}},error:function(){alert("something broke");}});
合并与压缩的时机
源代码映射文件
代码整理
自动化任务:Grunt
自动化任务:Gulp
grunt.initConfig({
sass: {
dist: {
files: [{
cwd: "app/styles",
src: "**/*.scss",
dest: "../.tmp/styles",
expand: true,
ext: ".css"
}]
}
},
autoprefixer: {
options: ["last 1 version"],
dist: {
files: [{
expand: true,
cwd: ".tmp/styles",
src: "{,*/}*.css",
dest: "dist/styles"
}]
}
},
watch: {
styles: {
files: ["app/styles/{,*/}*.scss"],
tasks: ["sass:dist", "autoprefixer:dist"]
}
}
});
grunt.registerTask("default", ["styles", "watch"]);
gulp.task("sass", function () {
gulp.src("app/styles/**/*.scss")
.pipe(sass())
.pipe(autoprefixer("last 1 version"))
.pipe(gulp.dest("dist/styles"));
});
gulp.task("default", function() {
gulp.run("sass");
gulp.watch("app/styles/**/*.scss", function() {
gulp.run("sass");
});
});
总结
Ressources