Install Astro
The create astro
CLI command is the fastest way to start a new Astro project from scratch. It will walk you through every step of setting up your new Astro project and allows you to choose from a few different official starter templates.
Or, you can begin your project using any existing theme or starter template.
To install manually instead, see our step-by-step manual installation guide.
Prefer to try Astro in your browser? Visit astro.new to browse our starter templates and spin up a new Astro project without ever leaving your browser.
Prerequisites
Section titled Prerequisites- Node.js -
v18.17.1
orv20.3.0
or higher. (v19
is not supported.) - Text editor - We recommend VS Code with our Official Astro extension.
- Terminal - Astro is accessed through its command-line interface (CLI).
Start a new project
Section titled Start a new projectInstall from the CLI wizard
Section titled Install from the CLI wizard-
Run the following command in your terminal to start our handy install wizard:
You can run
create astro
anywhere on your machine, so there’s no need to create a new empty directory for your project before you begin. If you don’t have an empty directory yet for your new project, the wizard will help create one for you automatically.If all goes well, you should see a success message followed by some recommended next steps.
cd
into your new project directory to begin using Astro. -
If you skipped the
npm install
step during the CLI wizard, then be sure to install your dependencies before continuing. -
You can now start the Astro dev server and see a live preview of your project while you build!
Use a theme or starter template
Section titled Use a theme or starter templateYou can also start a new astro project based on an official example or the main
branch of any GitHub repository by passing a --template
argument to the create astro
command.
-
Explore our themes and starters showcase where you can browse themes for blogs, portfolios, documentation sites, landing pages, and more! Or, search on GitHub for even more starter projects.
-
Run the following command in your terminal, substituting the official Astro starter template name, or the GitHub username and repository of the theme you want to use:
By default, this command will use the template repository’s
main
branch. To use a different branch name, pass it as part of the--template
argument:<github-username>/<github-repo>#<branch>
. -
Answer the questions and follow the instructions of the CLI wizard.
-
You can now start the Astro dev server and see a live preview of your project while you make it your own!
Manual Setup
Section titled Manual SetupThis guide will walk you through the steps to manually install and configure a new Astro project.
If you prefer not to use our automatic create astro
CLI tool, you can set up your project yourself by following the guide below.
-
Create your directory
Create an empty directory with the name of your project, and then navigate into it.
Once you are in your new directory, create your project
package.json
file. This is how you will manage your project dependencies, including Astro. If you aren’t familiar with this file format, run the following command to create one. -
Install Astro
First, install the Astro project dependencies inside your project.
Astro must be installed locally, not globally. Make sure you are not running
npm install -g astro
pnpm add -g astro
oryarn add global astro
.Then, replace any placeholder “scripts” section of your
package.json
with the following:You’ll use these scripts later in the guide to start Astro and run its different commands.
-
Create your first page
In your text editor, create a new file in your directory at
src/pages/index.astro
. This will be your first Astro page in the project.For this guide, copy-and-paste the following code snippet (including
---
dashes) into your new file: -
Create your first static asset
You will also want to create a
public/
directory to store your static assets. Astro will always include these assets in your final build, so you can safely reference them from inside your component templates.In your text editor, create a new file in your directory at
public/robots.txt
.robots.txt
is a simple file that most sites will include to tell search bots like Google how to treat your site.For this guide, copy-and-paste the following code snippet into your new file:
-
Create
astro.config.mjs
Astro is configured using
astro.config.mjs
. This file is optional if you do not need to configure Astro, but you may wish to create it now.Create
astro.config.mjs
at the root of your project, and copy the code below into it:If you want to include UI framework components such as React, Svelte, etc. or use other tools such as Tailwind or Partytown in your project, here is where you will manually import and configure integrations.
Read Astro’s API configuration reference for more information.
-
Add TypeScript support
TypeScript is configured using
tsconfig.json
. Even if you don’t write TypeScript code, this file is important so that tools like Astro and VS Code know how to understand your project. Some features (like npm package imports) aren’t fully supported in the editor without atsconfig.json
file.If you do intend to write TypeScript code, using Astro’s
strict
orstrictest
template is recommended. You can view and compare the three template configurations at astro/tsconfigs/.Create
tsconfig.json
at the root of your project, and copy the code below into it. (You can usebase
,strict
orstrictest
for your TypeScript template):Finally, create
src/env.d.ts
to let TypeScript know about ambient types available in an Astro project:Read Astro’s TypeScript setup guide for more information.
-
Next Steps
If you have followed the steps above, your project directory should now look like this:
Directorynode_modules/
- …
Directorypublic/
- robots.txt
Directorysrc/
Directorypages/
- index.astro
- env.d.ts
- astro.config.mjs
- package-lock.json or
yarn.lock
,pnpm-lock.yaml
, etc. - package.json
- tsconfig.json
-
You can now start the Astro dev server and see a live preview of your project while you build!
Start the Astro dev server
Section titled Start the Astro dev serverAstro comes with a built-in development server that has everything you need for project development. The astro dev
CLI command will start the local development server so that you can see your new website in action for the very first time.
Every starter template comes with a pre-configured script that will run astro dev
for you. After navigating into your project directory, use your favorite package manager to run this command and start the Astro development server.
If all goes well, Astro should now be serving your project on http://localhost:4321/. Visit that link in your browser and see your new site!
Work in development mode
Section titled Work in development modeAstro will listen for live file changes in your src/
directory and update your site preview as you build, so you will not need to restart the server as you make changes during development. You will always be able to see an up-to-date version of your site in your browser when the dev server is running.
When viewing your site in the browser, you’ll have access to the Astro dev toolbar. As you build, it will help you inspect your islands, spot accessibility issues, and more.
If you aren’t able to open your project in the browser after starting the dev server, go back to the terminal where you ran the dev
command and check the message displayed. It should tell you if an error occurred, or if your project is being served at a different URL than http://localhost:4321/.
Build and preview your site
Section titled Build and preview your siteTo check the version of your site that will be created at build time, quit the dev server and run the appropriate build command for your package manager in your terminal:
Astro will build a deploy-ready version of your site in a separate folder (dist/
by default) and you can watch its progress in the terminal. This will alert you to any build errors in your project before you deploy to production.
When the build is finished, run the appropriate preview
command in your terminal and you can view the built version of your site locally in the same browser preview window.
Deploy your new site
Section titled Deploy your new siteYou may wish to deploy your new site right away, before you begin to add or change too much code. This is helpful to get a minimal, working version of your site published and can save you extra time and effort troubleshooting your deployment later.
Next Steps
Section titled Next StepsSuccess! You are now ready to start building with Astro! 🥳
Here are a few things that we recommend exploring next. You can read them in any order. You can even leave our documentation for a bit and go play in your new Astro project codebase, coming back here whenever you run into trouble or have a question.