Content deleted Content added
m →History: Rm links to Wikidata per Wikipedia talk:Manual of Style/Archive 204#New RFC on linking to Wikidata, replaced: '''UglifyJS''' → '''UglifyJS'''<!--Q116250477--> (2) |
|||
(35 intermediate revisions by 20 users not shown) | |||
Line 1:
{{short description|Removal of unnecessary characters in code without changing its functionality}}
{{other uses|Minimisation (disambiguation){{!}}Minimisation}}
{{Redirect|Terser|the basic topic|terseness}}
{{Use dmy dates|date=September 2021}}
'''Minification''' (also '''minimisation''' or '''minimization''') is the process of removing all unnecessary characters from the [[source code]] of [[Interpreted language|interpreted programming languages]] or [[markup language]]s without changing its functionality. These unnecessary characters usually include [[
Minification can be distinguished from the more general concept of [[data compression]] in that the minified source can be interpreted immediately without the need for
The goals of minification are not the same as the goals of [[Obfuscated code|obfuscation]]; the former is often intended to be reversed using a [[pretty-print]]er{{citation needed|date=July 2020}} or unminifier. However, to achieve its goals, minification sometimes uses techniques also used by [[obfuscation]]; for example, shortening variable names and refactoring the [[source code]]. When minification uses such techniques, the [[pretty-print]]er or unminifier can only fully reverse the minification process if it is supplied details of the transformations done by such techniques. If not supplied those details, the reversed [[source code]] will contain different variable names and control flow, even though it will have the same functionality as the original [[source code]].
Line 18 ⟶ 19:
</syntaxhighlight>
is equivalent to but longer than
<syntaxhighlight lang="
for(var a=[],i=0
</syntaxhighlight>
==History==
In 2001 [[Douglas Crockford]] introduced '''JSMin''',<ref>{{Cite web |title=JSMin: The JavaScript Minifier |url=https://www.crockford.com/javascript/jsmin.html |website=Crockford.com |date=11 September 2001 |first=Douglas |last=Crockford |publisher=[[WP:SPS|Self-published]]|archive-url=https://web.archive.org/web/20020405140416/https://www.crockford.com/javascript/jsmin.html |archive-date=5 April 2002 }}</ref> which removed comments and whitespace from JavaScript code.<ref name=":1">{{Cite web |url = https://webplatform.github.io/docs/concepts/programming/javascript/minification/ |title = Code minification |website = webplatform.github.io |publisher=The WebPlatform Project |url-status = live |archive-url = https://web.archive.org/web/20160424125048/https://docs.webplatform.org/wiki/concepts/programming/javascript/minification |archive-date = 24 April 2016}}</ref> It was followed by '''YUI Compressor''' in 2007.<ref name=":1"/> In 2009, Google opened up its Closure toolkit, including '''Closure Compiler''' which contained a source mapping feature together with a Firefox extension called Closure Inspector.<ref>{{Cite web |url=https://arstechnica.com/information-technology/2009/11/google-opens-up-its-javascript-development-toolbox-to-all/ |title=Google opens up its JavaScript development toolbox to all |website=[[Ars Technica]] |first=Ryan |last=Paul |date=6 November 2009}}</ref> In 2010, Mihai Bazon introduced '''UglifyJS'''<!--Q116250477-->, which was superseded by UglifyJS2 in 2012; the rewrite was to allow for source map support.<ref>{{Cite web |url=http://lisperator.net/blog/should-you-switch-to-uglifyjs2/ |title=Should you switch to UglifyJS2? |last=Bazon |first=Mihai |website=lisperator.net |date=8 November 2012 |publisher=[[WP:SPS|Self-published]]}}</ref> From 2017, Alex Lam took over maintenance and development of UglifyJS2, replacing it with UglifyJS3 which unified the CLI with the API.<ref>{{Cite web |url=https://www.npmjs.com/package/uglify-js/v/3.0.0 |title=uglify-js NPM |website=npmjs.com |date=6 May 2017 }}</ref> In 2018, '''Terser'''<!--Q95961419--> has been forked from uglify-es<ref>{{Cite web |title=terser · JavaScript mangler and compressor toolkit for ES6+ |url=https://terser.org/ |access-date=2023-01-29 |website=terser.org}}</ref><ref>https://github.com//terser/commit/3ef6879ecafd12b57e575ec85e6104e71d5a1b6f {{dead link|date=January 2024}}</ref> and has gained momentum since; in 2020 it outstripped UglifyJS when measured in daily downloads.<ref>{{cite web | url=https://npmtrends.com/terser-vs-uglify-js | title=Terser vs uglify-js |website= NPM trends |url-status=live |archive-url=https://archive.today/20240127214344/https://npmtrends.com/terser-vs-uglify-js |archive-date= 27 January 2024}}</ref>
==Source mapping==
A '''
The original format was created by Joseph Schorr as part of the Closure Inspector minification project.<ref name=":0">{{Cite web|date=2011-01-11|title=Source Map Revision 3 Proposal|url=https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit|url-status=dead|archive-url=https://
==Types==
Line 35 ⟶ 36:
[[Visual Studio Code]] comes with minification support for several languages. It can readily browse the Visual Studio Marketplace to download and install additional minifiers.
JavaScript optimizers can minify and generate source maps. In addition certain online tools can compress [[Cascading Style Sheets|CSS]] files.<ref>{{Cite web |last=Megida |first=Dillion |date=2022-05-18 |title=Minify CSS – CSS Minifying and Compression Explained |url=https://www.freecodecamp.org/news/minify-css-css-minifying-and-compression-explained/#howtominifycss |access-date=2024-03-29 |website=Free Code Camp |language=en}}</ref>
===Web development===
Components and libraries for [[Web application]]s and websites have been developed to optimize file requests and reduce page load times by shrinking the size of various files.
JavaScript and [[Cascading Style
==References==
|