- AstroBeasties/v0.0.2Latest
- Inline/v0.1.4
- Inline/v0.1.3
- AstroBeasties/v0.0.1
- Inline/v0.1.2
- AstroCritters/v2.2.1
- Inline/v0.1.1
- AstroCritters/v2.2.0
- Inline/v0.1.0
- AstroCritters/v2.1.10
- 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
astro-critters 🦔
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.
Installation
There are two ways to add integrations to your project. Let’s try the most convenient option first!
(experimental) 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 astro-critters, 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-crittersInstall dependencies manually
First, install the astro-critters integration like so:
npm install astro-crittersThen, apply this integration to your astro.config.* file using the
integrations property:
astro.config.mjs
import { defineConfig } from "astro/config";
import critters from "astro-critters";
export default defineConfig({
// ...
integrations: [critters()],
});Getting started
Critters should now automatically inline the critical CSS of your HTML files.
You can override any of the default options from the configuration at https://github.com/GoogleChromeLabs/critters#properties. Path is “./dist/” by default as in the Astro configuration.
export interface Options {
path?: string;
publicPath?: string;
external?: boolean;
inlineThreshold?: number;
minimumExternalSize?: number;
pruneSource?: boolean;
mergeStylesheets?: boolean;
additionalStylesheets?: string[];
preload?: "body" | "media" | "swap" | "js" | "js-lazy";
noscriptFallback?: boolean;
inlineFonts?: boolean;
preloadFonts?: boolean;
fonts?: boolean;
keyframes?: string;
compress?: boolean;
logLevel?: "info" | "warn" | "error" | "trace" | "debug" | "silent";
reduceInlineStyles?: boolean;
logger?: Logger;
}Head to critters for all options and features available. You can also check the Astro Integration Documentation for more on integrations.