שאלות נפוצות
קל לארגן דפים בעזרת אוספים
אפשר לשמור ולסווג תוכן על סמך ההעדפות שלך.
-
מהו Closure Compiler? למה כדאי להשתמש בה?
-
Closure Compiler הוא כלי להורדה ולהרצה מהירות יותר של JavaScript. אפשר להשתמש ב-Closure Compiler כדי להקטין את הגודל של קובצי JavaScript ולשפר את היעילות שלהם.
-
מה ההבדל בין Closure Compiler לבין כלי דחיסה אחרים של JavaScript?
-
בדרך כלל, כלי ה-Closure Compiler אמור לעמוד בדרישות הדחיסה של כלי צמצום קוד אחרים או לעלות עליהן, ולשפר את זמני ההורדה של אפליקציית האינטרנט שלכם. בנוסף, Closure Compiler יכול לעזור לכם למצוא שגיאות בתחביר במהלך הפיתוח (ולא במהלך הבדיקה) ולזהות דפוסי קוד שעלולים להכיל באגים.
במצב פשוט, Closure Compiler אמור להיות יעיל יותר מכלים אחרים כי הוא משתמש בניתוח שדומה לניתוח של קומפיילר כדי למצוא דרכים נוספות לצמצם את גודל הקוד. לדוגמה, Closure Compiler יכול להחליף פונקציות שמשמשות רק בכמה מקרים, לעשות שימוש חוזר בשמות של משתנים ולבצע חישוב מראש של ביטויי קבועים.
במצב מתקדם, Closure Compiler יכול גם להשתמש בהערות מסוג שהוספתם כדי למצוא באגים שקשה לזהות.
-
האם אפשר להשתמש ב-Closure Compiler כדי לקמפל JavaScript שמוטמע ב-HTML?
-
לא. Closure Compiler פועל רק על קבצים שמכילים רק JavaScript.
-
האם אפשר להשתמש ב-Closure Compiler יחד עם כלי אחרים לצמצום קוד JavaScript?
-
כן. הכלי Closure Compiler קורא כל JavaScript תקין ומפיק JavaScript תקין, כך שאפשר להשתמש בו בקובץ JavaScript לפני או אחרי שמריצים את הקובץ באמצעות כלי אחר לצמצום קבצים.
חשוב לזכור ש-Closure Compiler וכלי מיניפיקציה אחרים עשויים להגדיר ציפיות לגבי הקוד הנכנס. לדוגמה, כלי לצמצום קוד שמסיר הערות עלול להסיר רישיונות או מידע על הערות שנדרשים לכלי אחר.
-
איך אפשר לנפות באגים ב-JavaScript שנוצר על ידי Closure Compiler?
-
אם הקוד שעבר קומפילציה מחזיר שגיאות או מתנהג בצורה לא צפויה,
אפשר להשתמש במיפוי קוד המקור כדי לנפות באגים בבעיה. מפת מקור מספקת מיפוי בין הקוד שעבר קומפילציה לבין קוד המקור המקורי, כך שהכלים למפתחים בדפדפן יכולים להציג את קוד המקור המקורי במקום הקוד שעבר קומפילציה.
כדי ש-Closure Compiler ייצור מפת מקור, מעבירים את האפשרות
--create_source_map
בשורת הפקודה. לדוגמה:
$ java -jar compiler.jar --js example.js --create_source_map ./example-map --js_output_file example-compiled.js
לאחר מכן, אם אתם משתמשים בדפדפן שתומך במיפוי קוד המקור (כמו Chrome או Firefox), אתם יכולים להגדיר נקודות עצירה בדיוק כמו שהייתם עושים בקוד שלא עבר קומפילציה, והכלים למפתחים בדפדפן יציגו את שורת הקוד התואמת במקור המקורי. מידע נוסף על הכלים למפתחים ב-Chrome, כולל מידע על מפות מקור, זמין במאמר ניפוי באגים ב-JavaScript.
-
האם הקומפיילר מבצע איזשהו איזון בין מהירות ההרצה של האפליקציה לבין גודל הקוד להורדה?
-
כן. כל קומפיילר שמבצע אופטימיזציה עושה פשרות. חלק מהאופטימיזציות של הגודל גורמות לעלייה קלה בעומס על המהירות. עם זאת, המפתחים של Closure Compiler הקפידו לא להוסיף זמן ריצה משמעותי. חלק מהאופטימיזציות של הקומפיילר אפילו מקטינות את זמן הריצה (ראו שאלה הבאה).
-
האם הקומפיילר מבצע אופטימיזציה למהירות?
-
ברוב המקרים, קוד קטן יותר הוא קוד מהיר יותר, כי זמן ההורדה הוא בדרך כלל הגורם הכי חשוב שמשפיע על המהירות באפליקציות אינטרנט. אופטימיזציות שמפחיתות את הכפילויות ומאיצות את זמן הריצה של הקוד.
-
האם יש הגבלות על גודל הקבצים שאפשר לקמפל?
-
לשירות האינטרנט של הקומפילציה יש גודל קובץ מקסימלי, אבל לאפליקציית הקומפיילר העצמאית אין.
-
האם Closure Compiler זמין לכל הפלטפורמות?
-
הקומפיילר כתוב ב-Java, כך שהוא יכול לפעול בכל מקום שבו Java פועלת.
-
האם הקומפיילר יכול לעבד כל JavaScript חוקי?
-
ברוב המקרים. חלק ממבני JavaScript, כולל
eval()
ו-with()
, עלולים לבטל הנחות שהטרנספורמציות של הקומפיילר מבוססות עליהן.
-
כמה ידע בפיתוח אתרים צריך כדי להשתמש ב-Closure Compiler?
-
Closure Compiler הוא כלי לפיתוח JavaScript, לכן צריך לדעת לתכנת ב-JavaScript כדי להשתמש בקומפיילר. אבל כל מי שמשתמש ב-JavaScript יכול להפיק תועלת משימוש ב-Closure Compiler.
-
איך Closure Compiler עובד עם Closure Library?
-
הכלי Closure Compiler מספק בדיקות מיוחדות ואופטימיזציות לקוד שמשתמש בספריית Closure. בנוסף, שירות Closure Compiler יכול לכלול באופן אוטומטי קבצים של Closure Library. בקטע Finding
Your Way around Closure מוסבר על התחביר להצהרה על החלקים של Closure שאתם צריכים. בהפניה ל-API מוסבר איך משתמשים בספריית Closure עם ה-API. כדי להשתמש ב-Closure Library עם אפליקציית Closure Compiler, צריך קודם להוריד את Closure Library. התמיכה בספריית Closure מופעלת באפליקציית הקומפיילר כברירת מחדל.
-
הקוד שלי מפסיק לפעול או שהקומפיילר מפיק שגיאות כשאני
מבצע קומפילציה באמצעות
ADVANCED_OPTIMIZATIONS
. למה?
-
בדרך כלל, כדי להשתמש במצב מתקדם צריך לבצע הכנות ולשנות את הקוד. במאמר Advanced Compilation and Externs מוסבר איך לוודא שהקוד פועל עם
ADVANCED_OPTIMIZATIONS
.
-
למה יש הזנות שורות אקראיות בסקריפטים שעברו קומפילציה?
-
המהדר של Closure מוסיף בכוונה מעברי שורה כל 500 תווים בערך. חומות אש ושרתי proxy לפעמים משחיתים או מתעלמים מקובצי JavaScript גדולים עם שורות ארוכות מאוד. כדי למנוע את הבעיה הזו, צריך להוסיף מעברי שורה כל 500 תווים. הסרת מעברי השורה לא משפיעה על הסמנטיקה של הסקריפט. ההשפעה על גודל הקוד קטנה, והקומפיילר מבצע אופטימיזציה של מיקום מעברי השורה כך שההשפעה על גודל הקוד תהיה קטנה עוד יותר כשמבצעים gzip לקבצים.
-
יש לי הודעות בנושא זכויות יוצרים או טקסט של רישיון קוד פתוח שחייבים להופיע בקוד המקור שלי. איך אפשר למנוע מ-Closure Compiler להסיר את הטקסט הזה?
-
Closure Compiler תומך בתג
@license
של JSDoc. מוסיפים את התג @license
לכל תגובת JSDoc כדי לשמור את התגובה בפלט של הקומפיילר. מידע נוסף זמין במאמר הוספת הערות ל-JavaScript עבור Closure Compiler.
אלא אם צוין אחרת, התוכן של דף זה הוא ברישיון Creative Commons Attribution 4.0 ודוגמאות הקוד הן ברישיון Apache 2.0. לפרטים, ניתן לעיין במדיניות האתר Google Developers. Java הוא סימן מסחרי רשום של חברת Oracle ו/או של השותפים העצמאיים שלה.
עדכון אחרון: 2025-07-26 (שעון UTC).
[null,null,["עדכון אחרון: 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."]]