This Astro integration generates a sitemap for your Astro project.
Sitemaps outline all of the pages, videos, and files on your site. Search engines like Google read this file to crawl your site more efficiently. See Google's own advice on sitemaps to learn more.
There are two ways to add integrations to your project. Let's try the most convenient option first!
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 @astrojs/sitemap
, run the following from your project directory and follow the prompts:
# Using NPM
npx astro add sitemap
# Using Yarn
yarn astro add sitemap
# Using PNPM
pnpx astro add sitemap
If you run into any hiccups, feel free to log an issue on our GitHub and try the manual installation steps below.
First, install the @astrojs/sitemap
integration like so:
npm install @astrojs/sitemap
Then, apply this integration to your astro.config.*
file using the integrations
property:
astro.config.mjs
import sitemap from '@astrojs/sitemap';
export default {
// ...
integrations: [sitemap()],
}
@astrojs/sitemap
requires a deployment / site URL for generation. Add your site's URL under your astro.config.*
using the site
property:
astro.config.mjs
import sitemap from '@astrojs/sitemap';
export default {
// ...
site: 'https://stargazers.club',
integrations: [sitemap()],
}
Now, build your site for production via the astro build
command. You should find your sitemap under dist/sitemap.xml
!
You can also check our Astro Integration Documentation for more on integrations.
All pages are included in your sitemap by default. By adding a custom filter
, you can filter included pages by URL.
astro.config.mjs
import sitemap from '@astrojs/sitemap';
export default {
site: 'https://stargazers.club',
integrations: [
sitemap({
filter: (page) => page !== 'https://stargazers.club/secret-vip-lounge'
}),
],
}
The page
function parameter is the full URL of your rendered page, including your site
domain. Return true
to include a page in your sitemap, and false
to remove it.
If present, we use the site
config option as the base for all sitemap URLs. Use canonicalURL
to override this.
astro.config.mjs
import sitemap from '@astrojs/sitemap';
export default {
site: 'https://stargazers.club',
integrations: [
sitemap({
// https://astronaut.party will be used for all sitemap URLs instead
canonicalURL: 'https://astronaut.party',
}),
],
}