Framework Components
Build your Astro website without sacrificing your favorite component framework.
Astro supports a variety of popular frameworks including React, Preact, Svelte, Vue, SolidJS, AlpineJS and Lit.
Installing Integrations
Section titled Installing IntegrationsAstro ships with optional integrations for React, Preact, Svelte, Vue, SolidJS, AlpineJS and Lit. One or several of these Astro integrations can be installed and configured in your project.
⚙️ View the Integrations Guide for more details on installing and configuring Astro integrations.
⚙️ Want to see an example for the framework of your choice? Visit astro.new and select one of the framework templates.
Using Framework Components
Section titled Using Framework ComponentsUse your JavaScript framework components in your Astro pages, layouts and components just like Astro components! All your components can live together in /src/components
, or can be organized in any way you like.
To use a framework component, import it from its relative path in your Astro component script. Then, use the component alongside other components, HTML elements and JSX-like expressions in the component template.
By default, your framework components will only render on the server, as static HTML. This is useful for templating components that are not interactive and avoids sending any unnecessary JavaScript to the client.
Hydrating Interactive Components
Section titled Hydrating Interactive ComponentsA framework component can be made interactive (hydrated) using a client:*
directive. These are component attributes that determine when your component’s JavaScript should be sent to the browser.
With all client directives except client:only
, your component will first render on the server to generate static HTML. Component JavaScript will be sent to the browser according to the directive you chose. The component will then hydrate and become interactive.
The JavaScript framework (React, Svelte, etc) needed to render the component will be sent to the browser along with the component’s own JavaScript. If two or more components on a page use the same framework, the framework will only be sent once.
Available Hydration Directives
Section titled Available Hydration DirectivesThere are several hydration directives available for UI framework components: client:load
, client:idle
, client:visible
, client:media={QUERY}
and client:only={FRAMEWORK}
.
📚 See our directives reference page for a full description of these hydration directives, and their usage.
Mixing Frameworks
Section titled Mixing FrameworksYou can import and render components from multiple frameworks in the same Astro component.
Passing Props to Framework Components
Section titled Passing Props to Framework ComponentsYou can pass props from Astro components to framework components:
Passing Children to Framework Components
Section titled Passing Children to Framework ComponentsInside of an Astro component, you can pass children to framework components. Each framework has its own patterns for how to reference these children: React, Preact, and Solid all use a special prop named children
, while Svelte and Vue use the <slot />
element.
Additionally, you can use Named Slots to group specific children together.
For React, Preact, and Solid these slots will be converted to a top-level prop. Slot names using kebab-case
will be converted to camelCase
.
For Svelte and Vue these slots can be referenced using a <slot>
element with the name
attribute. Slot names using kebab-case
will be preserved.
Nesting Framework Components
Section titled Nesting Framework ComponentsInside of an Astro file, framework component children can also be hydrated components. This means that you can recursively nest components from any of these frameworks.
This allows you to build entire “apps” in your preferred JavaScript framework and render them, via a parent component, to an Astro page.
Can I use Astro Components inside my Framework Components?
Section titled Can I use Astro Components inside my Framework Components?Any UI framework component becomes an “island” of that framework. These components must be written entirely as valid code for that framework, using only its own imports and packages. You cannot import .astro
components in a UI framework component (e.g. .jsx
or .svelte
).
You can, however, use the Astro <slot />
pattern to pass static content generated by Astro components as children to your framework components inside an .astro
component.
Can I Hydrate Astro Components?
Section titled Can I Hydrate Astro Components?If you try to hydrate an Astro component with a client:
modifier, you will get an error.
Astro components are HTML-only templating components with no client-side runtime. But, you can use a <script>
tag in your Astro component template to send JavaScript to the browser that executes in the global scope.
📚 Learn more about client-side <script>
tags in Astro components