Skip to content

πŸƒβ€β™‚οΈπŸƒβ€β™€οΈπŸƒ JS minification benchmarks: babel-minify, esbuild, terser, uglify-js, swc, google closure compiler, tdewolff/minify, oxc-minify

License

Notifications You must be signed in to change notification settings

privatenumber/minification-benchmarks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

minification benchmarks

What's the best JavaScript minifier?

This project benchmarks the following minifiers:

Minifier Version Release date ↓
bun 1.2.15 2025-05-28
google-closure-compiler 20250526.0.0 2025-05-28
oxc-minify 0.72.1 2025-05-28
terser 5.40.0 2025-05-27
esbuild 0.25.5 2025-05-27
@swc/core 1.11.29 2025-05-21
@tdewolff/minify 2.23.8 2025-05-21
uglify-js 3.19.3 2024-08-29
babel-minify 0.5.2 2022-05-06
tedivm/jshrink 1.7.0

Benchmarks last updated on May 28, 2025.


πŸ™‹β€β™‚οΈ Why?

  1. To help you pick a minifier that fits your needs
  2. To promote JS minifiers and document their performances
  3. 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
  • Each minifier is minimally configured (sourcemaps & comments disabled), comparing out-of-the-box experience
  • Minifier upgrade PRs are automated via WhiteSource Renovate
  • Benchmarks are updated on every PR via GitHub Actions
  • The raw benchmark data is available in /packages/data/data/data.json

⏱ 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

---
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,12]
	y-axis "Gzip size" 0 --> 19385
	bar [19385,8177,8186,8216,8265,8448,8493,8543,8628,8661,8668,8746,11040]
Loading
Artifact Original size Gzip size
react v17.0.2 (Source) 72.13 kB 19.39 kB
Minifier Minified size Minzipped size Time
1. uglify-js πŸ†-69% 22.64 kB πŸ†-58% 8.18 kB 189x 497 ms
2. @swc/core -68% 22.81 kB -58% 8.19 kB 5x 14 ms
3. google-closure-compiler -68% 22.84 kB -58% 8.22 kB 1257x 3,303 ms
4. terser -68% 23.07 kB -57% 8.27 kB 108x 285 ms
5. babel-minify -67% 23.60 kB -56% 8.45 kB 246x 647 ms
6. oxc-minify -67% 23.52 kB -56% 8.49 kB 1x 3 ms
7. esbuild -67% 23.70 kB -56% 8.54 kB 4x 13 ms
8. @tdewolff/minify -67% 23.49 kB -55% 8.63 kB πŸ† 3 ms
9. bun -67% 23.99 kB -55% 8.66 kB 5x 14 ms
10. uglify-js (no compress) -65% 25.03 kB -55% 8.67 kB 34x 91 ms
11. terser (no compress) -65% 25.08 kB -55% 8.75 kB 45x 120 ms
12. tedivm/jshrink -43% 40.82 kB -43% 11.04 kB 46x 123 ms

---
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,12]
	y-axis "Gzip size" 0 --> 36231
	bar [36231,18568,18690,18746,18923,19119,19260,19334,19478,19569,19683,19857,24998]
Loading
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 πŸ†-67% 57.73 kB πŸ†-49% 18.57 kB 206x 1,149 ms
2. terser -66% 59.14 kB -48% 18.69 kB 127x 711 ms
3. @swc/core -66% 58.43 kB -48% 18.75 kB 6x 35 ms
4. google-closure-compiler -66% 58.29 kB -48% 18.92 kB 650x 3,627 ms
5. babel-minify -66% 59.70 kB -47% 19.12 kB 262x 1,465 ms
6. oxc-minify -66% 59.52 kB -47% 19.26 kB 1x 8 ms
7. esbuild -66% 59.82 kB -47% 19.33 kB 3x 21 ms
8. @tdewolff/minify -66% 59.87 kB -46% 19.48 kB πŸ† 6 ms
9. uglify-js (no compress) -64% 62.50 kB -46% 19.57 kB 38x 215 ms
10. terser (no compress) -64% 63.15 kB -46% 19.68 kB 53x 298 ms
11. bun -64% 61.84 kB -45% 19.86 kB 3x 18 ms
12. tedivm/jshrink -44% 97.63 kB -31% 25.00 kB 50x 282 ms

---
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,12]
	y-axis "Gzip size" 0 --> 84498
	bar [84498,30866,30903,30913,30969,31446,31470,31621,31799,31954,32653,33092,40879]
Loading
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 -69% 89.17 kB πŸ†-63% 30.87 kB 6x 53 ms
2. uglify-js πŸ†-69% 88.45 kB -63% 30.90 kB 202x 1,593 ms
3. terser -69% 89.54 kB -63% 30.91 kB 122x 961 ms
4. oxc-minify -69% 89.33 kB -63% 30.97 kB 1x 12 ms
5. @tdewolff/minify -69% 89.68 kB -63% 31.45 kB πŸ† 8 ms
6. uglify-js (no compress) -67% 94.08 kB -63% 31.47 kB 39x 314 ms
7. terser (no compress) -67% 94.55 kB -63% 31.62 kB 48x 381 ms
8. babel-minify -68% 92.10 kB -62% 31.80 kB 304x 2,398 ms
9. esbuild -69% 90.07 kB -62% 31.95 kB 4x 36 ms
10. bun -68% 92.55 kB -61% 32.65 kB 3x 28 ms
11. google-closure-compiler -68% 92.73 kB -61% 33.09 kB 521x 4,108 ms
12. tedivm/jshrink -50% 144.14 kB -52% 40.88 kB 46x 363 ms

---
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,12]
	y-axis "Gzip size" 0 --> 89668
	bar [89668,42727,42919,43036,43357,43925,44184,44358,44368,44450,44679,45400,57169]
Loading
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 -66% 115.70 kB πŸ†-52% 42.73 kB 5x 72 ms
2. terser -66% 116.80 kB -52% 42.92 kB 91x 1,198 ms
3. uglify-js πŸ†-67% 113.80 kB -52% 43.04 kB 168x 2,206 ms
4. oxc-minify -66% 117.25 kB -52% 43.36 kB 1x 15 ms
5. babel-minify -66% 117.90 kB -51% 43.93 kB 206x 2,696 ms
6. google-closure-compiler -66% 115.61 kB -51% 44.18 kB 343x 4,496 ms
7. @tdewolff/minify -66% 117.69 kB -51% 44.36 kB πŸ† 13 ms
8. esbuild -65% 118.14 kB -51% 44.37 kB 3x 43 ms
9. uglify-js (no compress) -63% 126.14 kB -50% 44.45 kB 27x 364 ms
10. terser (no compress) -63% 126.58 kB -50% 44.68 kB 35x 470 ms
11. bun -64% 121.50 kB -49% 45.40 kB 2x 31 ms
12. tedivm/jshrink -42% 197.36 kB -36% 57.17 kB 36x 479 ms

---
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,12]
	y-axis "Gzip size" 0 --> 96690
	bar [96690,24686,25022,25186,25240,25503,25862,25979,26200,26221,26498,26655,36327]
Loading
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 πŸ†-87% 68.17 kB πŸ†-74% 24.69 kB 142x 1,689 ms
2. google-closure-compiler -86% 73.50 kB -74% 25.02 kB 359x 4,242 ms
3. terser -87% 70.67 kB -74% 25.19 kB 86x 1,021 ms
4. @swc/core -87% 69.82 kB -74% 25.24 kB 5x 62 ms
5. babel-minify -87% 72.37 kB -74% 25.50 kB 176x 2,083 ms
6. uglify-js (no compress) -86% 74.61 kB -73% 25.86 kB 28x 333 ms
7. oxc-minify -87% 71.38 kB -73% 25.98 kB 1x 12 ms
8. esbuild -87% 72.48 kB -73% 26.20 kB 2x 29 ms
9. terser (no compress) -86% 75.29 kB -73% 26.22 kB 34x 410 ms
10. @tdewolff/minify -87% 71.90 kB -73% 26.50 kB πŸ† 12 ms
11. bun -87% 73.45 kB -72% 26.66 kB 2x 24 ms
12. tedivm/jshrink -73% 148.78 kB -62% 36.33 kB 30x 365 ms

---
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,10]
	y-axis "Gzip size" 0 --> 130686
	bar [130686,87016,87205,88087,88148,88319,89156,89882,90800,92395,94166]
Loading
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 πŸ†-53% 263.56 kB πŸ†-33% 87.02 kB 121x 3,927 ms
2. @swc/core -52% 265.22 kB -33% 87.21 kB 4x 156 ms
3. terser -52% 267.78 kB -33% 88.09 kB 74x 2,407 ms
4. oxc-minify -51% 270.83 kB -33% 88.15 kB 1x 35 ms
5. uglify-js (no compress) -50% 275.35 kB -32% 88.32 kB 21x 711 ms
6. terser (no compress) -50% 276.47 kB -32% 89.16 kB 32x 1,061 ms
7. @tdewolff/minify -52% 269.35 kB -31% 89.88 kB πŸ† 32 ms
8. esbuild -51% 270.13 kB -31% 90.80 kB 2x 69 ms
9. bun -51% 273.41 kB -29% 92.40 kB 1x 46 ms
10. google-closure-compiler -51% 270.32 kB -28% 94.17 kB 202x 6,570 ms
11. babel-minify ❌ Minification ❌ ❌ -
12. tedivm/jshrink ❌ Minification ❌ ❌ -

---
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,11]
	y-axis "Gzip size" 0 --> 193763
	bar [193763,122353,123291,123334,123490,124428,124609,124885,126454,126707,127653,145178]
Loading
Artifact Original size Gzip size
terser v5.30.3 (Source) 1.01 MB 193.76 kB
Minifier Minified size Minzipped size Time
1. oxc-minify -56% 440.17 kB πŸ†-37% 122.35 kB 1x 36 ms
2. @swc/core -55% 455.63 kB -36% 123.29 kB 4x 145 ms
3. uglify-js -55% 451.19 kB -36% 123.33 kB 108x 3,787 ms
4. terser -55% 458.29 kB -36% 123.49 kB 65x 2,293 ms
5. terser (no compress) -53% 474.40 kB -36% 124.43 kB 29x 1,022 ms
6. uglify-js (no compress) -53% 472.16 kB -36% 124.61 kB 22x 778 ms
7. @tdewolff/minify -55% 456.59 kB -36% 124.89 kB πŸ† 35 ms
8. google-closure-compiler πŸ†-56% 439.97 kB -35% 126.45 kB 179x 6,238 ms
9. esbuild -55% 458.89 kB -35% 126.71 kB 1x 60 ms
10. bun -54% 466.80 kB -34% 127.65 kB 1x 43 ms
11. tedivm/jshrink -37% 633.71 kB -25% 145.18 kB 38x 1,341 ms
12. babel-minify ❌ Minification ❌ ❌ -

---
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,11]
	y-axis "Gzip size" 0 --> 248267
	bar [248267,158764,159071,159200,160827,162771,163036,163198,163725,164610,166210,193471]
Loading
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 -48% 643.05 kB πŸ†-36% 158.76 kB 4x 226 ms
2. uglify-js πŸ†-49% 641.59 kB -36% 159.07 kB 101x 5,046 ms
3. terser -48% 653.26 kB -36% 159.20 kB 63x 3,137 ms
4. oxc-minify -48% 647.00 kB -35% 160.83 kB 1x 54 ms
5. google-closure-compiler -48% 644.52 kB -34% 162.77 kB 153x 7,659 ms
6. uglify-js (no compress) -46% 674.49 kB -34% 163.04 kB 19x 994 ms
7. terser (no compress) -46% 675.50 kB -34% 163.20 kB 27x 1,361 ms
8. esbuild -48% 646.76 kB -34% 163.73 kB 1x 89 ms
9. @tdewolff/minify -48% 642.46 kB -34% 164.61 kB πŸ† 50 ms
10. bun -47% 655.93 kB -33% 166.21 kB 1x 54 ms
11. tedivm/jshrink -24% 952.01 kB -22% 193.47 kB 34x 1,715 ms
12. babel-minify ❌ Timed out - - ⚠️ +10,000 ms

---
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,9]
	y-axis "Gzip size" 0 --> 309942
	bar [309942,157435,157843,158710,162248,165014,166386,167579,181071,182671]
Loading
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 πŸ†-67% 694.78 kB πŸ†-49% 157.44 kB 120x 6,579 ms
2. @swc/core -67% 706.21 kB -49% 157.84 kB 6x 330 ms
3. terser -66% 715.59 kB -49% 158.71 kB 77x 4,225 ms
4. oxc-minify -66% 716.13 kB -48% 162.25 kB 1x 77 ms
5. @tdewolff/minify -66% 717.07 kB -47% 165.01 kB πŸ† 55 ms
6. terser (no compress) -64% 759.34 kB -46% 166.39 kB 30x 1,688 ms
7. uglify-js (no compress) -65% 756.53 kB -46% 167.58 kB 23x 1,314 ms
8. esbuild -66% 724.14 kB -42% 181.07 kB 2x 123 ms
9. bun -66% 727.90 kB -41% 182.67 kB 1x 78 ms
10. google-closure-compiler ❌ Timed out - - ⚠️ +10,000 ms
11. babel-minify ❌ Minification ❌ ❌ -
12. tedivm/jshrink ❌ Post-validation ❌ ❌ -

---
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,8]
	y-axis "Gzip size" 0 --> 684611
	bar [684611,321255,321986,324608,330736,331412,331563,331847,337934]
Loading
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 πŸ†-69% 994.54 kB πŸ†-53% 321.26 kB 5x 630 ms
2. terser -69% 1.00 MB -53% 321.99 kB 52x 6,346 ms
3. oxc-minify -69% 1.01 MB -53% 324.61 kB 1x 147 ms
4. terser (no compress) -66% 1.07 MB -52% 330.74 kB 22x 2,767 ms
5. uglify-js (no compress) -67% 1.07 MB -52% 331.41 kB 14x 1,756 ms
6. esbuild -68% 1.01 MB -52% 331.56 kB 1x 194 ms
7. @tdewolff/minify -68% 1.01 MB -52% 331.85 kB πŸ† 121 ms
8. bun -68% 1.02 MB -51% 337.93 kB 1x 123 ms
9. babel-minify ❌ Timed out - - ⚠️ +10,000 ms
10. uglify-js ❌ Timed out - - ⚠️ +10,000 ms
11. google-closure-compiler ❌ Timed out - - ⚠️ +10,000 ms
12. tedivm/jshrink ❌ Minification ❌ ❌ -

---
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,8]
	y-axis "Gzip size" 0 --> 825175
	bar [825175,452477,457789,463332,471791,475480,478572,488279,491833]
Loading
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 πŸ†-68% 2.15 MB πŸ†-45% 452.48 kB 6x 858 ms
2. terser -66% 2.25 MB -45% 457.79 kB 49x 7,047 ms
3. oxc-minify -66% 2.28 MB -44% 463.33 kB 1x 192 ms
4. @tdewolff/minify -66% 2.29 MB -43% 471.79 kB πŸ† 141 ms
5. terser (no compress) -64% 2.43 MB -42% 475.48 kB 22x 3,187 ms
6. uglify-js (no compress) -64% 2.42 MB -42% 478.57 kB 17x 2,525 ms
7. esbuild -65% 2.31 MB -41% 488.28 kB 2x 306 ms
8. bun -66% 2.30 MB -40% 491.83 kB 1x 170 ms
9. babel-minify ❌ Timed out - - ⚠️ +10,000 ms
10. tedivm/jshrink ❌ Timed out - - ⚠️ +10,000 ms
11. uglify-js ❌ Timed out - - ⚠️ +10,000 ms
12. google-closure-compiler ❌ Timed out - - ⚠️ +10,000 ms

---
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,6]
	y-axis "Gzip size" 0 --> 1884998
	bar [1884998,859199,860657,875817,876535,879301,915551]
Loading
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 πŸ†-70% 3.31 MB πŸ†-54% 859.20 kB 6x 1,745 ms
2. oxc-minify -69% 3.35 MB -54% 860.66 kB 1x 387 ms
3. @tdewolff/minify -69% 3.35 MB -54% 875.82 kB πŸ† 259 ms
4. uglify-js (no compress) -68% 3.54 MB -53% 876.54 kB 15x 4,029 ms
5. terser (no compress) -68% 3.53 MB -53% 879.30 kB 21x 5,450 ms
6. esbuild -68% 3.49 MB -51% 915.55 kB 1x 497 ms
7. terser ❌ Timed out - - ⚠️ +10,000 ms
8. babel-minify ❌ Timed out - - ⚠️ +10,000 ms
9. uglify-js ❌ Timed out - - ⚠️ +10,000 ms
10. tedivm/jshrink ❌ Timed out - - ⚠️ +10,000 ms
11. google-closure-compiler ❌ Timed out - - ⚠️ +10,000 ms
12. bun ❌ Post-validation ❌ ❌ -

βš”οΈ Minifier showdown

Note

πŸ€– This analysis is AI generated

Hold onto your hats, everyone! We've just raced through an incredible showdown of JavaScript minifiers. From gzip size pyrotechnics to blazing-fast processing speeds, it’s a thrilling tale of victory margins and jaw-dropping defeats. Let’s dive into the highlights from this grueling, code-crunching arena!

Best Minifier

Drumroll... The title of Best Minifier goes to @swc/core! This overachiever has consistently achieved some of the smallest gzip sizes across various package sizes without breaking a sweat. It's also a speed demon. Take Round 6 ("d3"), where it crushed the race in only 156 ms while producing a stunning 87.21 kB outputβ€”just 0.19 kB behind the much slower uglify-js (3,927 ms). Whether it’s tiny utilities or hulking libraries like ECharts or TypeScript, @swc/core delivers both compression and speed with effortless grace. For the average user who wants great results with zero compromise, @swc/core is the one minifier to rule them all!

Honorable Mentions

Several minifiers put up heroic performances, and they deserve a standing ovation:

  1. uglify-js – The master tactician of compression! For the absolute smallest gzip sizes, it reigned supreme in more than half of the rounds. Take Round 9 ("victory")β€”uglify-js stunned with a mere 157.44 kB output. However, with speeds often measured in seconds, it’s best suited for fire-and-forget build processes rather than quick iterations.

  2. @tdewolff/minify – The reigning speed champion! Whether it was "lodash" (12 ms), "antd" (141 ms), or "d3" (32 ms), this minifier crushed times across the board. While its gzip sizes weren’t chart-toppers, they held their own respectably. Ideal for workflows prioritizing lightning-fast feedback.

  3. oxc-minify – The rising star of balanced performance. Often finishing in the top four for both size and speed, this contender’s Round 7 triumph (122.35 kB in 36 ms for "terser") shows it’s ready to claim its seat at the grown-up table. A promising pick for power users.

  4. terser – A reliable pick with strong gzip size compression and processing times that are respectable, though unspectacular. For those wanting a popular and widely-trusted minifier, terser won’t disappoint despite getting edged out by better performers.

Eliminated

Oh no! Some competitors didn’t make it to the finish. Diplomatic applause aside, here’s why you should steer clear of these next time:

  • babel-minify: Ran aground spectacularly on "d3" with an "undefined property" error. Not only did it flop mid-race, but the project hasn't seen updates in years.
  • tedivm/jshrink: With an "unclosed regex pattern" fiasco, JShrink tumbled during Round 6. It’s clear this one isn’t prepared for modern JavaScript complexities.
  • bun: Script-breaking issues in post-validation ("Expected values to be strictly equal") on "typescript" did away with its hopes. Bun’s ambitions are bold, but it’s not there yet.

What an electrifying showdown! Congratulations to all competitors for pushing the boundaries of what minifiers can do. @swc/core, hats off to you for holding your ground as the best all-rounder. For those seeking specialty tools, uglify-js, @tdewolff/minify, and oxc-minify have carved out their niches brilliantly. Here’s to more cutthroat competition and compressed code ahead!

Sponsors

About

πŸƒβ€β™‚οΈπŸƒβ€β™€οΈπŸƒ JS minification benchmarks: babel-minify, esbuild, terser, uglify-js, swc, google closure compiler, tdewolff/minify, oxc-minify

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project

 

Contributors 9