Questions fréquentes
Restez organisé à l'aide des collections
Enregistrez et classez les contenus selon vos préférences.
-
Qu'est-ce que Closure Compiler ? Pourquoi l'utiliser ?
-
Le compilateur Closure est un outil permettant d'accélérer le téléchargement et l'exécution de JavaScript. Vous pouvez utiliser Closure Compiler pour réduire la taille de vos fichiers JavaScript et les rendre plus efficaces.
-
En quoi le Closure Compiler se distingue-t-il des autres compresseurs JavaScript disponibles ?
-
En général, le compilateur Closure devrait égaler ou dépasser la compression des autres outils de minification de code, et améliorer les temps de téléchargement de votre application Web. De plus, Closure Compiler peut vous aider à trouver les erreurs de syntaxe pendant le développement (plutôt que pendant les tests) et à identifier les modèles de code potentiellement bogués.
En mode Simple, Closure Compiler devrait être plus efficace que les autres outils, car il utilise une analyse de type compilateur pour trouver d'autres moyens de minimiser la taille du code. Par exemple, le Closure Compiler peut intégrer des fonctions qui ne sont utilisées que quelques fois, réutiliser des noms de variables et précalculer des expressions constantes.
En mode avancé, Closure Compiler peut également utiliser les annotations de type que vous avez ajoutées pour trouver des bugs difficiles à repérer.
-
Le compilateur Closure peut-il compiler du code JavaScript intégré dans du code HTML ?
-
Non. Le compilateur Closure ne fonctionne que sur les fichiers qui ne contiennent que du code JavaScript.
-
Puis-je utiliser Closure Compiler avec d'autres outils de minification JavaScript ?
-
Oui. Closure Compiler lit tout code JavaScript valide et génère du code JavaScript valide. Vous pouvez donc appliquer Closure Compiler à un fichier JavaScript avant ou après l'avoir exécuté avec un autre outil de minification.
N'oubliez pas que Closure Compiler et d'autres outils de minification peuvent avoir des attentes concernant le code entrant. Un outil de minification qui supprime les commentaires peut supprimer des licences ou des informations d'annotation nécessaires à un autre outil, par exemple.
-
Comment déboguer le code JavaScript produit par Closure Compiler ?
-
Si votre code compilé génère des erreurs ou présente un comportement inattendu,
vous pouvez utiliser les cartes sources pour déboguer le problème. Un mappage source fournit un mappage entre le code compilé et le code source d'origine. Les outils de développement du navigateur peuvent ainsi afficher votre code source d'origine au lieu du code compilé.
Pour que Closure Compiler génère une carte source, transmettez l'indicateur
--create_source_map
sur la ligne de commande. Exemple :
$ java -jar compiler.jar --js example.js --create_source_map ./example-map --js_output_file example-compiled.js
Ensuite, si vous utilisez un navigateur compatible avec les cartes sources (comme Chrome
ou Firefox), vous pouvez définir des points d'arrêt comme vous le feriez pour du code non compilé.
Les outils de développement du navigateur afficheront la ligne de code correspondante
dans la source d'origine. Pour en savoir plus sur les outils pour les développeurs Chrome, y compris sur les cartes sources, consultez Déboguer JavaScript.
-
Le compilateur fait-il un compromis entre la vitesse d'exécution et la taille du code de téléchargement de mon application ?
-
Oui. Tout compilateur d'optimisation fait des compromis. Certaines optimisations de taille entraînent de légers ralentissements. Toutefois, les développeurs de Closure Compiler ont veillé à ne pas introduire de temps d'exécution supplémentaire important. Certaines optimisations du compilateur diminuent même le temps d'exécution (voir la question suivante).
-
Le compilateur optimise-t-il la vitesse ?
-
Dans la plupart des cas, un code plus petit est un code plus rapide, car le temps de téléchargement est généralement le facteur de vitesse le plus important dans les applications Web. Les optimisations qui réduisent les redondances accélèrent également le temps d'exécution du code.
-
La taille des fichiers pouvant être compilés est-elle limitée ?
-
Le service Web de compilation a une taille de fichier maximale, mais l'application de compilation autonome n'en a pas.
-
Le Closure Compiler est-il disponible pour toutes les plates-formes ?
-
Le compilateur est écrit en Java, il peut donc s'exécuter partout où Java s'exécute.
-
Le compilateur peut-il traiter n'importe quel code JavaScript légal ?
-
Généralement. Certains éléments de construction JavaScript, y compris
eval()
et with()
, peuvent invalider les hypothèses sur lesquelles reposent les transformations du compilateur.
-
Quelles connaissances en développement Web dois-je avoir pour utiliser le Closure Compiler ?
-
Le compilateur Closure est un outil de développement JavaScript. Vous devez donc savoir programmer en JavaScript pour l'utiliser. Toute personne qui utilise JavaScript peut bénéficier de l'utilisation du compilateur Closure.
-
Comment le compilateur Closure fonctionne-t-il avec la bibliothèque Closure ?
-
Le compilateur Closure fournit des vérifications et des optimisations spéciales pour le code qui utilise la bibliothèque Closure. De plus, le service Closure Compiler peut inclure automatiquement les fichiers Closure Library. Trouver votre chemin dans Closure décrit la syntaxe pour déclarer les parties de Closure dont vous avez besoin. Pour en savoir plus sur l'utilisation de la bibliothèque Closure avec l'API, consultez la documentation de référence de l'API. Pour utiliser la bibliothèque Closure avec l'application Closure Compiler, vous devez d'abord télécharger la bibliothèque Closure. La compatibilité avec la bibliothèque Closure est activée par défaut dans l'application du compilateur.
-
Mon code cesse de fonctionner ou le compilateur génère des erreurs lorsque je compile avec
ADVANCED_OPTIMIZATIONS
. Pourquoi ?
-
L'utilisation du mode avancé nécessite généralement une certaine préparation et des modifications du code. Compilation avancée et fichiers externes explique comment vous assurer que votre code fonctionne avec
ADVANCED_OPTIMIZATIONS
.
-
Pourquoi des retours à la ligne aléatoires apparaissent-ils dans les scripts compilés ?
-
Le compilateur Closure ajoute intentionnellement des sauts de ligne environ tous les 500 caractères. Les pare-feu et les proxys corrompent ou ignorent parfois les fichiers JavaScript volumineux avec des lignes très longues. Pour éviter ce problème, ajoutez des sauts de ligne tous les 500 caractères. La suppression des sauts de ligne n'a aucune incidence sur la sémantique d'un script. L'impact sur la taille du code est faible, et le compilateur optimise l'emplacement des sauts de ligne afin que la pénalité de taille du code soit encore plus faible lorsque les fichiers sont compressés au format Gzip.
-
J'ai des mentions de copyright ou du texte de licence Open Source qui doivent apparaître dans mon code source. Comment empêcher Closure Compiler de supprimer ce texte ?
-
Closure Compiler est compatible avec la balise JSDoc
@license
. Ajoutez la balise @license
à n'importe quel commentaire JSDoc pour conserver le commentaire dans le résultat du compilateur. Pour en savoir plus, consultez Annotating JavaScript for the Closure Compiler (Annoter JavaScript pour le compilateur Closure).
Sauf indication contraire, le contenu de cette page est régi par une licence Creative Commons Attribution 4.0, et les échantillons de code sont régis par une licence Apache 2.0. Pour en savoir plus, consultez les Règles du site Google Developers. Java est une marque déposée d'Oracle et/ou de ses sociétés affiliées.
Dernière mise à jour le 2025/07/26 (UTC).
[[["Facile à comprendre","easyToUnderstand","thumb-up"],["J'ai pu résoudre mon problème","solvedMyProblem","thumb-up"],["Autre","otherUp","thumb-up"]],[["Il n'y a pas l'information dont j'ai besoin","missingTheInformationINeed","thumb-down"],["Trop compliqué/Trop d'étapes","tooComplicatedTooManySteps","thumb-down"],["Obsolète","outOfDate","thumb-down"],["Problème de traduction","translationIssue","thumb-down"],["Mauvais exemple/Erreur de code","samplesCodeIssue","thumb-down"],["Autre","otherDown","thumb-down"]],["Dernière mise à jour le 2025/07/26 (UTC)."],[[["\u003cp\u003eThe Closure Compiler is a tool for making JavaScript download and run faster by reducing file size and improving efficiency.\u003c/p\u003e\n"],["\u003cp\u003eIt offers greater compression than standard minifiers and helps identify syntax errors and potential bugs during development.\u003c/p\u003e\n"],["\u003cp\u003eThe Closure Compiler works with any valid JavaScript and can be used alongside other minifiers for enhanced optimization.\u003c/p\u003e\n"],["\u003cp\u003eSource maps enable debugging of compiled code by providing a mapping back to the original source.\u003c/p\u003e\n"],["\u003cp\u003eWhile prioritizing download speed, the compiler also performs optimizations to enhance execution speed without significant runtime overhead.\u003c/p\u003e\n"]]],[],null,["# Frequently Asked Questions\n\n- [What is the Closure Compiler? Why should I use it?](#what)\n- [How is the Closure Compiler different\n from the other JavaScript compressors that are out there?](#how-different)\n- [Can the Closure Compiler compile JavaScript that's embedded in HTML?](#tags)\n- [Can I use the Closure Compiler together with other JavaScript\n minifiers?](#other-minifiers)\n- [How can I debug the JavaScript that the Closure Compiler produces?](#sourcemaps)\n- [Does the compiler make any trade-off between my application's\n execution speed and download code size?](#tradeoffs)\n- [Does the compiler optimize for speed?](#speed)\n- [Are there any restrictions on the size of the files that can be compiled?](#size-restrictions)\n- [Is the Closure Compiler available for all platforms?](#platforms)\n- [Can the Compiler process any legal JavaScript?](#restrictions)\n- [How does the Closure Compiler work with\n the Closure Library?](#how-closure)\n- [My code stops working or the Compiler produces\n errors when I compile\n with `ADVANCED_OPTIMIZATIONS`. Why?](#advanced)\n- [Why are there random line feeds in\n compiled scripts?](#linefeeds)\n- [I have copyright notices or open source license\n text that must appear in my source code. How do I keep the Closure\n Compiler from stripping this text out?](#license)\n\n\u003cbr /\u003e\n\n\u003cbr /\u003e\n\n\nWhat is the Closure Compiler? Why should I use it?\n:\n The Closure Compiler is a tool for making JavaScript download and\n run faster. You can use the Closure Compiler to reduce the size of\n your JavaScript files and to make them more efficient.\n\n\nHow is the Closure Compiler different from the other JavaScript\ncompressors that are out there?\n\n: Generally, the Closure Compiler should meet or exceed the compression\n of other code minification tools, and improve download times for your\n web application. In addition, the Closure Compiler can help you\n find syntax errors during development (rather than during testing)\n and identify potentially buggy code patterns.\n\n In Simple mode, Closure Compiler should be able to do better than\n other tools because it uses compiler-like analysis to find additional\n ways to minimize code size. For example, the Closure Compiler can\n inline functions that are used in only a few occurrences, reuse\n variable names, and pre-compute constant expressions.\n\n In Advanced mode, Closure Compiler can also use your added type\n annotations to find hard-to-spot bugs.\n\n\nCan the Closure Compiler compile JavaScript that's embedded in HTML?\n:\n No. The Closure Compiler works only on files that contain only JavaScript.\n\n\nCan I use the Closure Compiler together with other JavaScript\nminifiers?\n\n: Yes. Closure Compiler reads in any valid JavaScript and generates\n valid JavaScript, so you can apply the Closure Compiler to a\n JavaScript file either before or after you run the file through a\n different minifier.\n\n Remember that Closure Compiler and other minifiers might have\n expectations about the incoming code. A minifier that strips\n comments may remove licenses or annotation information needed by\n another tool, for example.\n\n\nHow can I debug the JavaScript that the Closure Compiler produces?\n:\n If your compiled code is throwing errors or exhibiting unexpected behavior,\n you can use Source Maps to debug the issue. A source map provides a mapping\n between the compiled code and the original source code so that the browser's\n developer tools can show you your original source code instead of the compiled code.\n To make the Closure Compiler produce a source map, pass the\n `--create_source_map` flag on the command line. For example: \n\n ```\n $ java -jar compiler.jar --js example.js --create_source_map ./example-map --js_output_file example-compiled.js\n ```\n\n Then, if you're using a browser that supports Source Maps (such as Chrome\n or Firefox), you can set breakpoints just as you would for uncompiled code,\n and the browser's developer tools will show the corresponding line of code\n in the original source. For more information about Chrome's developer tools, including\n information about source maps, see\n [Debugging JavaScript](https://developers.google.com/chrome-developer-tools/docs/javascript-debugging).\n\n\nDoes the compiler make any trade-off between my application's\nexecution speed and download code size?\n:\n Yes. Any optimizing compiler makes trade-offs. Some size\n optimizations do introduce small speed overheads. However, the\n Closure Compiler's developers have been careful not to introduce\n significant additional runtime. Some of the compiler's\n optimizations even decrease runtime (see next question).\n\n\nDoes the compiler optimize for speed?\n:\n In most cases smaller code is faster code, since download time is usually the most important speed factor in web applications. Optimizations that\n reduce redundancies speed up the run time of code as well.\n\n\nAre there any restrictions on the size of the files that can be compiled?\n:\n The compilation web service has a maximum file size, but the\n standalone compiler application does not.\n\n\nIs the Closure Compiler avalable for all platforms?\n:\n The compiler is written in Java, so it can run anywhere Java runs.\n\n\nCan the Compiler process any legal JavaScript?\n:\n Mostly. Some JavaScript constructs, including `eval()`\n and `with()`, can invalidate assumptions on which the\n compiler's transformations are based.\n\n\nHow much do I need to know about web development to use the\nClosure Compiler?\n:\n The Closure Compiler is a tool for JavaScript development, so you\n do need to know how to program in JavaScript to use the\n compiler. But anyone who uses JavaScript can benefit from using\n the Closure Compiler.\n\n\nHow does the Closure Compiler work with the Closure Library?\n:\n The Closure Compiler provides special checks and optimizations for\n code that uses the Closure Library. In addition, the Closure\n Compiler service can automatically include Closure Library\n files. [Finding\n Your Way around Closure](/closure/library/docs/introduction#deps) describes the syntax for declaring the\n parts of Closure that you need. See\n the [API\n reference](/closure/compiler/docs/api-ref#closure) for information on using the Closure Library with the\n API. To use the Closure Library with the Closure Compiler\n application you must\n first [download\n the Closure Library](https://github.com/google/closure-library). Support for the Closure Library is\n enabled in the compiler application by default.\n\n\nMy code stops working or the Compiler produces errors when I\ncompile with `ADVANCED_OPTIMIZATIONS`. Why?\n:\n Using Advanced mode usually requires some preparation and code\n changes. [Advanced Compilation\n and Externs](/closure/compiler/docs/api-tutorial3) explains how to make sure your code works\n with `ADVANCED_OPTIMIZATIONS`.\n\n\nWhy are there random line feeds in compiled scripts?\n:\n The Closure Compiler intentionally adds line breaks every 500\n characters or so. Firewalls and proxies sometimes corrupt or\n ignore large JavaScript files with very long lines. Adding line\n breaks every 500 characters prevents this problem. Removing the\n line breaks has no effect on a script's semantics. The impact on code size is small, and the Compiler\n optimizes line break placement so that the code size penalty is even smaller when files are gzipped.\n\n\nI have copyright notices or open source\nlicense text that must appear in my source code. How do I keep the\nClosure Compiler from stripping this text out?\n:\n Closure Compiler supports the JSDoc `@license` tag. Add the\n `@license` tag to any JSDoc comment to preserve the\n comment in the compiler\n output. See [Annotating\n JavaScript for the Closure Compiler](/closure/compiler/docs/js-for-compiler#tag-license) for more information."]]