- v1.1.40Latest
- v1.1.38
- v1.1.37
- v1.1.36
- v1.1.35
- v1.1.34
- v1.1.33
- v1.1.32
- v1.1.31
- v1.1.30
- v1.1.29
- v1.1.28
- v1.1.27
- v1.1.26
- v1.1.25
- v1.1.24
- v1.1.23
- v1.1.22
- v1.1.21
- v1.1.20
- v1.1.19
- v1.1.18
- v1.1.17
- v1.1.16
- v1.1.15
- v1.1.14
- v1.1.13
- v1.1.12
- v1.1.11
- v1.1.10
- v1.1.9
- v1.1.8
- v1.1.7
- v1.1.6
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.12
- 1.0.12
- v0.0.1
- v1.0.11
- v1.0.10
- v1.0.9
- v1.0.8
- v1.0.7
- v1.0.6
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- v0.0.19
- v0.0.18
- v0.0.17
- v0.0.16
- v0.0.15
- v0.0.14
- v0.0.13
- v0.0.12
astro-compress ๐๏ธ
This Astro integration brings compression utilities to your Astro project.
csso html-minifier-terser terser sharp svgo
Installation
There are two ways to add integrations to your project. Letโs try the most convenient option first!
astro add
command
(experimental) Astro includes a CLI tool for adding first party integrations: astro add
. This
command will:
- (Optionally) Install all necessary dependencies and peer dependencies
- (Also optionally) Update your
astro.config.*
file to apply this integration
To install astro-compress
, run the following from your project directory and
follow the prompts:
# Using NPM
npx astro add astro-compress
# Using Yarn
yarn astro add astro-compress
# Using PNPM
pnpx astro add astro-compress
Install dependencies manually
First, install the astro-compress
integration like so:
npm install astro-compress
Then, apply this integration to your astro.config.*
file using the
integrations
property:
astro.config.mjs
import { defineConfig } from "astro/config";
import compress from "astro-compress";
export default defineConfig({
// ...
integrations: [compress()],
});
Getting started
The utility should now automatically compress all your CSS, HTML and JavaScript files in the dist folder.
The following image file types will also be compressed.
- avci
- avcs
- avif
- avifs
- gif
- heic
- heics
- heif
- heifs
- jfif
- jif
- jpe
- jpeg
- jpg
- png
- raw
- tiff
- webp
SVG compression is supported, as well via svgo.
You can override any of the default options from the configurations of:
or disable them entirely:
import { defineConfig } from "astro/config";
import compress from "astro-compress";
export default defineConfig({
integrations: [
compress({
css: false,
html: false,
js: false,
img: false,
svg: false,
}),
],
});
If your path is different than dist be sure to update it accordingly:
import { defineConfig } from "astro/config";
import compress from "astro-compress";
export default defineConfig({
outDir: "./build",
integrations: [
compress({
path: "./build",
}),
],
});
Set logger to 0 if you do not want to see debug messages. Default is 2.
import { defineConfig } from "astro/config";
import compress from "astro-compress";
export default defineConfig({
integrations: [
compress({
logger: 0,
}),
],
});