Awesome
<p align="center">
<img width="160" src=".github/logo.webp">
</p>
<h1 align="center">
<sup>minification benchmarks</sup>
</h1>
What's the best JavaScript minifier?
This project benchmarks the following minifiers:
<!-- minifiers:start -->
<!-- minifiers:end -->
Benchmarks last updated on <!-- lastUpdated:start -->Aug 14, 2024<!-- lastUpdated:end -->.
<br>
<p align="center">
<a href="https://github.com/sponsors/privatenumber/sponsorships?tier_id=398771"><img width="412" src="https://raw.githubusercontent.com/privatenumber/sponsors/master/banners/assets/donate.webp"></a>
<a href="https://github.com/sponsors/privatenumber/sponsorships?tier_id=397608"><img width="412" src="https://raw.githubusercontent.com/privatenumber/sponsors/master/banners/assets/sponsor.webp"></a>
</p>
🙋♂️ Why?
- To help you pick a minifier that fits your needs
- To promote JS minifiers and document their performances
- To encourage healthy competition and improvement amongst minifiers
👟 Methodology
- Each minifier is executed in its own process with a 10s timeout
- Artifact integrity is verified by a test before and after minification
- Minifier upgrade PRs are automated via WhiteSource Renovate
- Benchmarks are updated on every PR via GitHub Actions
⏱ Metrics
Minifiers are ranked by smallest minzipped size.
Minified size
Size of the minified output.
Minzipped size
Size of the minified output with Gzip compression.
For minifiers, this measures how compressable the output is.
For users, this measures network transfer size, which is usually the metric that matters most.
Time
How long minification took (average of 5 runs). Each time is annotated with a multiplier relative to the fastest minifier.
📋 Results
<!-- benchmarks:start -->
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "react v17.0.2"
x-axis ["Original",1,2,3,4,5,6,7,8,9,10,11]
y-axis "Gzip size" 0 --> 19385
bar [19385,8173,8177,8193,8317,8448,8543,8631,8651,8668,8746,11040]
<div align="center">
Artifact | Original size | Gzip size | |
---|
react v17.0.2 (Source) | 72.13 kB | 19.39 kB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>-68% </sup>22.87 kB | <sup>🏆-58% </sup>8.17 kB | <sup>8x </sup>21 ms |
2. uglify-js | <sup>🏆-69% </sup>22.64 kB | <sup>-58% </sup>8.18 kB | <sup>232x </sup>588 ms |
3. google-closure-compiler | <sup>-68% </sup>22.83 kB | <sup>-58% </sup>8.19 kB | <sup>1291x </sup>3,269 ms |
4. terser | <sup>-68% </sup>23.14 kB | <sup>-57% </sup>8.32 kB | <sup>108x </sup>274 ms |
5. babel-minify | <sup>-67% </sup>23.60 kB | <sup>-56% </sup>8.45 kB | <sup>233x </sup>590 ms |
6. esbuild | <sup>-67% </sup>23.70 kB | <sup>-56% </sup>8.54 kB | <sup>5x </sup>13 ms |
7. @tdewolff/minify | <sup>-67% </sup>23.53 kB | <sup>-55% </sup>8.63 kB | <sup>🏆 </sup>3 ms |
8. bun | <sup>-67% </sup>24.01 kB | <sup>-55% </sup>8.65 kB | <sup>5x </sup>14 ms |
9. uglify-js (no compress) | <sup>-65% </sup>25.03 kB | <sup>-55% </sup>8.67 kB | <sup>43x </sup>110 ms |
10. terser (no compress) | <sup>-65% </sup>25.08 kB | <sup>-55% </sup>8.75 kB | <sup>48x </sup>122 ms |
11. tedivm/jshrink | <sup>-43% </sup>40.82 kB | <sup>-43% </sup>11.04 kB | <sup>41x </sup>105 ms |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "moment v2.29.1"
x-axis ["Original",1,2,3,4,5,6,7,8,9,10,11]
y-axis "Gzip size" 0 --> 36231
bar [36231,18568,18686,18690,18910,19119,19334,19496,19569,19683,19850,24998]
<div align="center">
Artifact | Original size | Gzip size | |
---|
moment v2.29.1 (Source) | 173.90 kB | 36.23 kB | |
Minifier | Minified size | Minzipped size | Time |
1. uglify-js | <sup>🏆-67% </sup>57.73 kB | <sup>🏆-49% </sup>18.57 kB | <sup>264x </sup>1,433 ms |
2. @swc/core | <sup>-67% </sup>58.21 kB | <sup>-48% </sup>18.69 kB | <sup>9x </sup>51 ms |
3. terser | <sup>-66% </sup>59.14 kB | <sup>-48% </sup>18.69 kB | <sup>124x </sup>677 ms |
4. google-closure-compiler | <sup>-66% </sup>58.27 kB | <sup>-48% </sup>18.91 kB | <sup>711x </sup>3,856 ms |
5. babel-minify | <sup>-66% </sup>59.70 kB | <sup>-47% </sup>19.12 kB | <sup>252x </sup>1,367 ms |
6. esbuild | <sup>-66% </sup>59.82 kB | <sup>-47% </sup>19.33 kB | <sup>4x </sup>23 ms |
7. @tdewolff/minify | <sup>-66% </sup>59.95 kB | <sup>-46% </sup>19.50 kB | <sup>🏆 </sup>5 ms |
8. uglify-js (no compress) | <sup>-64% </sup>62.50 kB | <sup>-46% </sup>19.57 kB | <sup>49x </sup>267 ms |
9. terser (no compress) | <sup>-64% </sup>63.15 kB | <sup>-46% </sup>19.68 kB | <sup>51x </sup>279 ms |
10. bun | <sup>-64% </sup>61.84 kB | <sup>-45% </sup>19.85 kB | <sup>3x </sup>17 ms |
11. tedivm/jshrink | <sup>-44% </sup>97.63 kB | <sup>-31% </sup>25.00 kB | <sup>45x </sup>246 ms |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "jquery v3.5.1"
x-axis ["Original",1,2,3,4,5,6,7,8,9,10,11]
y-axis "Gzip size" 0 --> 84498
bar [84498,30867,30903,30912,31468,31470,31621,31799,31954,32630,33086,40879]
<div align="center">
Artifact | Original size | Gzip size | |
---|
jquery v3.5.1 (Source) | 287.63 kB | 84.50 kB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>-69% </sup>89.15 kB | <sup>🏆-63% </sup>30.87 kB | <sup>10x </sup>92 ms |
2. uglify-js | <sup>🏆-69% </sup>88.45 kB | <sup>-63% </sup>30.90 kB | <sup>229x </sup>1,956 ms |
3. terser | <sup>-69% </sup>89.54 kB | <sup>-63% </sup>30.91 kB | <sup>106x </sup>904 ms |
4. @tdewolff/minify | <sup>-69% </sup>89.85 kB | <sup>-63% </sup>31.47 kB | <sup>🏆 </sup>9 ms |
5. uglify-js (no compress) | <sup>-67% </sup>94.08 kB | <sup>-63% </sup>31.47 kB | <sup>47x </sup>407 ms |
6. terser (no compress) | <sup>-67% </sup>94.55 kB | <sup>-63% </sup>31.62 kB | <sup>42x </sup>365 ms |
7. babel-minify | <sup>-68% </sup>92.10 kB | <sup>-62% </sup>31.80 kB | <sup>264x </sup>2,255 ms |
8. esbuild | <sup>-69% </sup>90.07 kB | <sup>-62% </sup>31.95 kB | <sup>4x </sup>39 ms |
9. bun | <sup>-68% </sup>92.56 kB | <sup>-61% </sup>32.63 kB | <sup>3x </sup>27 ms |
10. google-closure-compiler | <sup>-68% </sup>92.70 kB | <sup>-61% </sup>33.09 kB | <sup>511x </sup>4,363 ms |
11. tedivm/jshrink | <sup>-50% </sup>144.14 kB | <sup>-52% </sup>40.88 kB | <sup>36x </sup>315 ms |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "vue v2.6.12"
x-axis ["Original",1,2,3,4,5,6,7,8,9,10,11]
y-axis "Gzip size" 0 --> 89668
bar [89668,42478,42939,43036,43925,44230,44368,44376,44450,44679,45340,57169]
<div align="center">
Artifact | Original size | Gzip size | |
---|
vue v2.6.12 (Source) | 342.15 kB | 89.67 kB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>-66% </sup>115.47 kB | <sup>🏆-53% </sup>42.48 kB | <sup>11x </sup>133 ms |
2. terser | <sup>-66% </sup>116.83 kB | <sup>-52% </sup>42.94 kB | <sup>95x </sup>1,120 ms |
3. uglify-js | <sup>🏆-67% </sup>113.80 kB | <sup>-52% </sup>43.04 kB | <sup>231x </sup>2,706 ms |
4. babel-minify | <sup>-66% </sup>117.90 kB | <sup>-51% </sup>43.93 kB | <sup>211x </sup>2,476 ms |
5. google-closure-compiler | <sup>-66% </sup>115.61 kB | <sup>-51% </sup>44.23 kB | <sup>403x </sup>4,717 ms |
6. esbuild | <sup>-65% </sup>118.14 kB | <sup>-51% </sup>44.37 kB | <sup>3x </sup>40 ms |
7. @tdewolff/minify | <sup>-66% </sup>117.81 kB | <sup>-51% </sup>44.38 kB | <sup>🏆 </sup>12 ms |
8. uglify-js (no compress) | <sup>-63% </sup>126.14 kB | <sup>-50% </sup>44.45 kB | <sup>38x </sup>444 ms |
9. terser (no compress) | <sup>-63% </sup>126.58 kB | <sup>-50% </sup>44.68 kB | <sup>38x </sup>445 ms |
10. bun | <sup>-64% </sup>121.70 kB | <sup>-49% </sup>45.34 kB | <sup>2x </sup>28 ms |
11. tedivm/jshrink | <sup>-42% </sup>197.36 kB | <sup>-36% </sup>57.17 kB | <sup>35x </sup>416 ms |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "lodash v4.17.21"
x-axis ["Original",1,2,3,4,5,6,7,8,9,10,11]
y-axis "Gzip size" 0 --> 96690
bar [96690,24686,24972,25180,25186,25503,25862,26200,26221,26469,26498,36327]
<div align="center">
Artifact | Original size | Gzip size | |
---|
lodash v4.17.21 (Source) | 544.09 kB | 96.69 kB | |
Minifier | Minified size | Minzipped size | Time |
1. uglify-js | <sup>🏆-87% </sup>68.17 kB | <sup>🏆-74% </sup>24.69 kB | <sup>174x </sup>2,067 ms |
2. google-closure-compiler | <sup>-86% </sup>73.47 kB | <sup>-74% </sup>24.97 kB | <sup>390x </sup>4,633 ms |
3. @swc/core | <sup>-87% </sup>69.84 kB | <sup>-74% </sup>25.18 kB | <sup>9x </sup>113 ms |
4. terser | <sup>-87% </sup>70.67 kB | <sup>-74% </sup>25.19 kB | <sup>79x </sup>946 ms |
5. babel-minify | <sup>-87% </sup>72.37 kB | <sup>-74% </sup>25.50 kB | <sup>163x </sup>1,940 ms |
6. uglify-js (no compress) | <sup>-86% </sup>74.61 kB | <sup>-73% </sup>25.86 kB | <sup>34x </sup>408 ms |
7. esbuild | <sup>-87% </sup>72.48 kB | <sup>-73% </sup>26.20 kB | <sup>2x </sup>29 ms |
8. terser (no compress) | <sup>-86% </sup>75.29 kB | <sup>-73% </sup>26.22 kB | <sup>32x </sup>382 ms |
9. bun | <sup>-86% </sup>74.11 kB | <sup>-73% </sup>26.47 kB | <sup>1x </sup>21 ms |
10. @tdewolff/minify | <sup>-87% </sup>71.90 kB | <sup>-73% </sup>26.50 kB | <sup>🏆 </sup>12 ms |
11. tedivm/jshrink | <sup>-73% </sup>148.78 kB | <sup>-62% </sup>36.33 kB | <sup>27x </sup>328 ms |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "d3 v6.3.1"
x-axis ["Original",1,2,3,4,5,6,7,8,9]
y-axis "Gzip size" 0 --> 130686
bar [130686,87016,87283,88319,88343,89156,89891,90800,92372,94121]
<div align="center">
Artifact | Original size | Gzip size | |
---|
d3 v6.3.1 (Source) | 555.77 kB | 130.69 kB | |
Minifier | Minified size | Minzipped size | Time |
1. uglify-js | <sup>🏆-53% </sup>263.56 kB | <sup>🏆-33% </sup>87.02 kB | <sup>146x </sup>5,067 ms |
2. @swc/core | <sup>-52% </sup>265.27 kB | <sup>-33% </sup>87.28 kB | <sup>8x </sup>292 ms |
3. uglify-js (no compress) | <sup>-50% </sup>275.35 kB | <sup>-32% </sup>88.32 kB | <sup>25x </sup>885 ms |
4. terser | <sup>-52% </sup>267.90 kB | <sup>-32% </sup>88.34 kB | <sup>66x </sup>2,300 ms |
5. terser (no compress) | <sup>-50% </sup>276.47 kB | <sup>-32% </sup>89.16 kB | <sup>29x </sup>1,010 ms |
6. @tdewolff/minify | <sup>-51% </sup>269.93 kB | <sup>-31% </sup>89.89 kB | <sup>🏆 </sup>35 ms |
7. esbuild | <sup>-51% </sup>270.13 kB | <sup>-31% </sup>90.80 kB | <sup>2x </sup>70 ms |
8. bun | <sup>-51% </sup>273.42 kB | <sup>-29% </sup>92.37 kB | <sup>1x </sup>42 ms |
9. google-closure-compiler | <sup>-51% </sup>270.30 kB | <sup>-28% </sup>94.12 kB | <sup>205x </sup>7,110 ms |
10. babel-minify <sub title="Failed: minification">❌ Minification</sub> | ❌ | ❌ | - |
11. tedivm/jshrink <sub title="Failed: minification">❌ Minification</sub> | ❌ | ❌ | - |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "terser v5.30.3"
x-axis ["Original",1,2,3,4,5,6,7,8,9,10]
y-axis "Gzip size" 0 --> 193763
bar [193763,123068,123334,123502,124428,124609,124897,126562,126706,127547,145178]
<div align="center">
Artifact | Original size | Gzip size | |
---|
terser v5.30.3 (Source) | 1.01 MB | 193.76 kB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>-55% </sup>455.58 kB | <sup>🏆-36% </sup>123.07 kB | <sup>7x </sup>250 ms |
2. uglify-js | <sup>-55% </sup>451.19 kB | <sup>-36% </sup>123.33 kB | <sup>153x </sup>4,971 ms |
3. terser | <sup>-55% </sup>458.31 kB | <sup>-36% </sup>123.50 kB | <sup>67x </sup>2,196 ms |
4. terser (no compress) | <sup>-53% </sup>474.40 kB | <sup>-36% </sup>124.43 kB | <sup>30x </sup>985 ms |
5. uglify-js (no compress) | <sup>-53% </sup>472.16 kB | <sup>-36% </sup>124.61 kB | <sup>35x </sup>1,152 ms |
6. @tdewolff/minify | <sup>-55% </sup>456.70 kB | <sup>-36% </sup>124.90 kB | <sup>🏆 </sup>32 ms |
7. google-closure-compiler | <sup>🏆-56% </sup>439.95 kB | <sup>-35% </sup>126.56 kB | <sup>205x </sup>6,631 ms |
8. esbuild | <sup>-55% </sup>458.89 kB | <sup>-35% </sup>126.71 kB | <sup>1x </sup>62 ms |
9. bun | <sup>-54% </sup>466.95 kB | <sup>-34% </sup>127.55 kB | <sup>1x </sup>37 ms |
10. tedivm/jshrink | <sup>-37% </sup>633.71 kB | <sup>-25% </sup>145.18 kB | <sup>36x </sup>1,185 ms |
11. babel-minify <sub title="Failed: minification">❌ Minification</sub> | ❌ | ❌ | - |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "three v0.124.0"
x-axis ["Original",1,2,3,4,5,6,7,8,9,10]
y-axis "Gzip size" 0 --> 248267
bar [248267,158374,159071,159729,162998,163036,163198,163725,164737,166430,193471]
<div align="center">
Artifact | Original size | Gzip size | |
---|
three v0.124.0 (Source) | 1.25 MB | 248.27 kB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>-48% </sup>642.91 kB | <sup>🏆-36% </sup>158.37 kB | <sup>8x </sup>379 ms |
2. uglify-js | <sup>🏆-49% </sup>641.59 kB | <sup>-36% </sup>159.07 kB | <sup>144x </sup>6,664 ms |
3. terser | <sup>-48% </sup>653.99 kB | <sup>-36% </sup>159.73 kB | <sup>64x </sup>2,976 ms |
4. google-closure-compiler | <sup>-48% </sup>644.45 kB | <sup>-34% </sup>163.00 kB | <sup>177x </sup>8,208 ms |
5. uglify-js (no compress) | <sup>-46% </sup>674.49 kB | <sup>-34% </sup>163.04 kB | <sup>26x </sup>1,245 ms |
6. terser (no compress) | <sup>-46% </sup>675.50 kB | <sup>-34% </sup>163.20 kB | <sup>28x </sup>1,306 ms |
7. esbuild | <sup>-48% </sup>646.76 kB | <sup>-34% </sup>163.73 kB | <sup>1x </sup>87 ms |
8. @tdewolff/minify | <sup>-48% </sup>644.55 kB | <sup>-34% </sup>164.74 kB | <sup>1x </sup>48 ms |
9. bun | <sup>-47% </sup>662.49 kB | <sup>-33% </sup>166.43 kB | <sup>🏆 </sup>46 ms |
10. tedivm/jshrink | <sup>-24% </sup>952.01 kB | <sup>-22% </sup>193.47 kB | <sup>32x </sup>1,519 ms |
11. babel-minify <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "victory v35.8.4"
x-axis ["Original",1,2,3,4,5,6,7,8]
y-axis "Gzip size" 0 --> 309942
bar [309942,157435,157861,158718,165131,166386,167579,181071,182626]
<div align="center">
Artifact | Original size | Gzip size | |
---|
victory v35.8.4 (Source) | 2.13 MB | 309.94 kB | |
Minifier | Minified size | Minzipped size | Time |
1. uglify-js | <sup>🏆-67% </sup>694.78 kB | <sup>🏆-49% </sup>157.44 kB | <sup>136x </sup>8,142 ms |
2. @swc/core | <sup>-67% </sup>707.22 kB | <sup>-49% </sup>157.86 kB | <sup>9x </sup>554 ms |
3. terser | <sup>-66% </sup>715.59 kB | <sup>-49% </sup>158.72 kB | <sup>67x </sup>3,997 ms |
4. @tdewolff/minify | <sup>-66% </sup>718.73 kB | <sup>-47% </sup>165.13 kB | <sup>🏆 </sup>59 ms |
5. terser (no compress) | <sup>-64% </sup>759.34 kB | <sup>-46% </sup>166.39 kB | <sup>27x </sup>1,616 ms |
6. uglify-js (no compress) | <sup>-65% </sup>756.53 kB | <sup>-46% </sup>167.58 kB | <sup>28x </sup>1,689 ms |
7. esbuild | <sup>-66% </sup>724.14 kB | <sup>-42% </sup>181.07 kB | <sup>1x </sup>116 ms |
8. bun | <sup>-66% </sup>727.99 kB | <sup>-41% </sup>182.63 kB | <sup>1x </sup>64 ms |
9. google-closure-compiler <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
10. babel-minify <sub title="Failed: minification">❌ Minification</sub> | ❌ | ❌ | - |
11. tedivm/jshrink <sub title="Failed: post-validation">❌ Post-validation</sub> | ❌ | ❌ | - |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "echarts v5.1.1"
x-axis ["Original",1,2,3,4,5,6,7]
y-axis "Gzip size" 0 --> 684611
bar [684611,320241,322101,330736,331412,331563,331791,337695]
<div align="center">
Artifact | Original size | Gzip size | |
---|
echarts v5.1.1 (Source) | 3.20 MB | 684.61 kB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>🏆-69% </sup>993.11 kB | <sup>🏆-53% </sup>320.24 kB | <sup>10x </sup>1,088 ms |
2. terser | <sup>-69% </sup>1.00 MB | <sup>-53% </sup>322.10 kB | <sup>56x </sup>6,075 ms |
3. terser (no compress) | <sup>-66% </sup>1.07 MB | <sup>-52% </sup>330.74 kB | <sup>24x </sup>2,689 ms |
4. uglify-js (no compress) | <sup>-67% </sup>1.07 MB | <sup>-52% </sup>331.41 kB | <sup>20x </sup>2,230 ms |
5. esbuild | <sup>-68% </sup>1.01 MB | <sup>-52% </sup>331.56 kB | <sup>1x </sup>194 ms |
6. @tdewolff/minify | <sup>-68% </sup>1.01 MB | <sup>-52% </sup>331.79 kB | <sup>1x </sup>123 ms |
7. bun | <sup>-68% </sup>1.03 MB | <sup>-51% </sup>337.70 kB | <sup>🏆 </sup>108 ms |
8. babel-minify <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
9. google-closure-compiler <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
10. uglify-js <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
11. tedivm/jshrink <sub title="Failed: minification">❌ Minification</sub> | ❌ | ❌ | - |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "antd v4.16.1"
x-axis ["Original",1,2,3,4,5,6,7]
y-axis "Gzip size" 0 --> 825175
bar [825175,452876,457821,472052,475480,478572,488279,491746]
<div align="center">
Artifact | Original size | Gzip size | |
---|
antd v4.16.1 (Source) | 6.67 MB | 825.18 kB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>🏆-68% </sup>2.15 MB | <sup>🏆-45% </sup>452.88 kB | <sup>9x </sup>1,368 ms |
2. terser | <sup>-66% </sup>2.25 MB | <sup>-45% </sup>457.82 kB | <sup>48x </sup>6,873 ms |
3. @tdewolff/minify | <sup>-66% </sup>2.30 MB | <sup>-43% </sup>472.05 kB | <sup>1x </sup>147 ms |
4. terser (no compress) | <sup>-64% </sup>2.43 MB | <sup>-42% </sup>475.48 kB | <sup>22x </sup>3,119 ms |
5. uglify-js (no compress) | <sup>-64% </sup>2.42 MB | <sup>-42% </sup>478.57 kB | <sup>22x </sup>3,193 ms |
6. esbuild | <sup>-65% </sup>2.31 MB | <sup>-41% </sup>488.28 kB | <sup>2x </sup>290 ms |
7. bun | <sup>-66% </sup>2.30 MB | <sup>-40% </sup>491.75 kB | <sup>🏆 </sup>141 ms |
8. babel-minify <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
9. google-closure-compiler <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
10. tedivm/jshrink <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
11. uglify-js <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
</div>
---
config:
xyChart:
width: 720
height: 360
xAxis:
labelPadding: 20
yAxis:
labelPadding: 10
---
xychart-beta
title "typescript v4.9.5"
x-axis ["Original",1,2,3,4,5]
y-axis "Gzip size" 0 --> 1884998
bar [1884998,852317,876535,876658,879301,915495]
<div align="center">
Artifact | Original size | Gzip size | |
---|
typescript v4.9.5 (Source) | 10.95 MB | 1.88 MB | |
Minifier | Minified size | Minzipped size | Time |
1. @swc/core | <sup>🏆-70% </sup>3.31 MB | <sup>🏆-55% </sup>852.32 kB | <sup>10x </sup>2,781 ms |
2. uglify-js (no compress) | <sup>-68% </sup>3.54 MB | <sup>-53% </sup>876.54 kB | <sup>19x </sup>5,075 ms |
3. @tdewolff/minify | <sup>-69% </sup>3.36 MB | <sup>-53% </sup>876.66 kB | <sup>🏆 </sup>264 ms |
4. terser (no compress) | <sup>-68% </sup>3.53 MB | <sup>-53% </sup>879.30 kB | <sup>19x </sup>5,281 ms |
5. esbuild | <sup>-68% </sup>3.49 MB | <sup>-51% </sup>915.50 kB | <sup>1x </sup>481 ms |
6. terser <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
7. babel-minify <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
8. google-closure-compiler <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
9. uglify-js <sub title="Failed: timeout">❌ Timed out</sub> | - | - | <sup>:warning:</sup> +10,000 ms |
10. tedivm/jshrink <sub title="Failed: minification">❌ Minification</sub> | ❌ | ❌ | - |
11. bun <sub title="Failed: post-validation">❌ Post-validation</sub> | ❌ | ❌ | - |
</div>
<!-- benchmarks:end -->
Sponsors
<p align="center">
<a href="https://github.com/sponsors/privatenumber">
<img src="https://cdn.jsdelivr.net/gh/privatenumber/sponsors/sponsorkit/sponsors.svg">
</a>
</p>