- AstroCritters/v2.1.10Latest
- Inline/v0.0.7
- AstroCritters/v2.1.9
- Inline/v0.0.6
- Inline/v0.0.5
- AstroCritters/v2.1.8
- Inline/v0.0.4
- AstroCritters/v2.1.7
- Inline/v0.0.3
- Inline/v0.0.2
- Inline/v0.0.1
- CrittersAstro/v0.0.2
- CrittersAstro/v0.0.1
- v2.1.6
- v2.1.5
- v2.1.4
- v2.1.3
- v2.1.2
- v2.1.0
- v2.0.11
- v2.0.10
- v2.0.9
- v2.0.8
- v2.0.7
- v2.0.6
- v1.1.40
- v1.1.39
- v1.1.38
- v1.1.37
- v1.1.35
- v1.1.36
- 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
- 1.0.5
- v1.0.4
- v1.0.3
- v1.0.2
- v1.0.1
- v1.0.0
- v0.0.11
- v0.0.10
- v0.0.9
Related | |||
AstroCompress 🗜️ AstroJS compression utilities. Compress HTML, CSS, JavaScript and more! | AstroRome 🏛️ AstroJS Rome tools. Format, lint and check your Astro website with Rome. |
AstroCritters 🦔
This Astro integration brings critters to your Astro project.
Critters is a plugin that inlines your app’s critical CSS and lazy-loads the rest.
Note
AstroCritters will not inline your requests, only your statically generated build and pre-rendered routes.
Installation
There are two ways to add integrations to your project. Let’s try the most convenient option first!
astro add
command
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 AstroCritters, run the following from your project directory and follow the prompts:
Using NPM:
npx astro add astro-critters
Using Yarn:
yarn astro add astro-critters
Using PNPM:
pnpx astro add astro-critters
Install dependencies manually
First, install the AstroCritters integration like so:
npm install -D -E astro-critters
Then, apply this integration to your astro.config.*
file using the
integrations
property:
import Critters from "astro-critters";
export default {
integrations: [Critters()],
};
Getting started
Critters will now automatically inline the critical CSS of your HTML files.
You can override any of the default options from the configuration of:
or disable them entirely:
import Critters from "astro-critters";
export default {
integrations: [
Critters({
Critters: false,
}),
],
};
path
variable.
You can add multiple paths to inline by specifying an array as the astro.config.ts
import Critters from "astro-critters";
export default {
integrations: [
Critters({
Path: ["./Target", "./Build"],
}),
],
};
You can also provide a map of paths for different input output directories.
astro.config.ts
import Critters from "astro-critters";
export default {
integrations: [
Critters({
Path: new Map([["./Source", "./Target"]]),
}),
],
};
Or an array of the two.
astro.config.ts
import Critters from "astro-critters";
export default {
integrations: [
Critters({
Path: [
// Inline Target
"./Target",
// Inline Target one more time into a different directory
new Map([["./Target", "./TargetInline"]]),
],
}),
],
};
You can provide a filter to exclude files in your build. A filter can be an array of regexes or a single match. You can use functions, as well to match on file names.
astro.config.ts
import Critters from "astro-critters";
export default {
integrations: [
Critters({
Exclude: [
"File.html",
(File: string) => File === "./Target/index.html",
],
}),
],
};
Logger
to 0
if you do not want to see debug messages. Default is 2
.
Set import Critters from "astro-critters";
export default {
integrations: [
Critters({
Logger: 0,
}),
],
};
Changelog
See CHANGELOG.md for a history of changes to this integration.