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 ↓
terser 5.40.0 2025-05-27
esbuild 0.25.5 2025-05-27
oxc-minify 0.72.0 2025-05-24
google-closure-compiler 20250520.0.0 2025-05-22
bun 1.2.14 2025-05-21
@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 27, 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 1160x 3,049 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 652x 3,637 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 7 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 19 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 509x 4,012 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,493 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 354x 4,185 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 25 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 48 ms
10. google-closure-compiler -51% 270.32 kB -28% 94.17 kB 204x 6,610 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 35 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 178x 6,222 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 42 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 157x 7,827 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 56 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 73 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 79 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 153 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 126 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 199 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 173 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 398 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

The battle of the JavaScript minifiers has been intense! We've seen jaw-dropping speed, mind-boggling compression ratios, and a few casualties along the way. Let’s recap the highlights and crown the winners of this electrifying showdown!

Best minifier

Drumroll, please... @swc/core storms ahead to claim the crown! Across a variety of scenarios, it consistently delivered stellar compression ratios while maintaining lightning-fast speeds. It dazzled us with a blistering 14 ms on React, aced the massive ECharts and Antd benchmarks with robust compression, and emerged unscathed from the heavyweight TypeScript match at just 859.20 kB. While not always the fastest, @swc/core strikes a winning balance between size and speed. For the average user who values a high-performance, no-fuss solution, this is the one to beat!

Honorable mentions

  1. Uglify-js: The precision and sheer compression power of Uglify-js were stunning, with top-notch results in almost every roundβ€”including being the reigning champion on Moment.js and lodash! However, its performance dropped off drastically as file size grew, with timeout issues in extreme benchmarks.
  2. Terser: Packing a punch with robust compression and high effectiveness, Terser came in near the top on many rounds. While it offers powerful capabilities, it struggled with processing speed as sizes grew, timing out on larger files.
  3. @tdewolff/minify: The speed demon of this competition! For users who prioritize blindingly fast minification speeds and can live with slightly less aggressive compression, this is an excellent choice. It breezed through every round with sub-200ms times, proving its worth for continuous build systems.
  4. OXC-minify: A dark horse in the race that prioritized rapidity while rarely sacrificing too much compression. It even topped the massive β€œterser” package, making a strong case for itself.

Eliminated

  1. Babel-minify: Stumbled on the β€œd3” package with fatal errors. A promising contender, but its inability to handle certain ES patterns makes it unreliable for production-grade builds.
  2. Tedivm/jshrink: Couldn’t finish the race due to Regex challenges during β€œd3,” showing its limitations with complex libraries.
  3. Bun: While speedy, it failed in post-validation (TypeScript), outputting incorrect results. A cautionary tale: correctness matters as much as speed and compression.

Quick outro

What a thrilling face-off! Every contender showed their strengths, and @swc/core emerged as a well-rounded champion with outstanding results. Uglify-js and Terser proved their compression prowess in tougher terrains, while @tdewolff/minify stole the show with its breakneck speeds. Hats off to these tools for pushing boundariesβ€”now go build something awesome with your newfound minification champion!

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