Using MDX in Astro

Learn how to use MDX in your Astro project to create dynamic content with embedded components.

Using MDX in Astro

This theme comes with the @astrojs/mdx integration installed and configured in your astro.config.mjs config file. If you prefer not to use MDX, you can disable support by removing the integration from your config file.

Why MDX?

MDX is a special flavor of Markdown that supports embedded JavaScript & JSX syntax. This unlocks the ability to mix JavaScript and UI Components into your Markdown content for things like interactive charts or alerts.

If you have existing content authored in MDX, this integration will hopefully make migrating to Astro a breeze.

Example

Here is how you import and use a UI component inside of MDX. When you open this page in the browser, you should see the clickable button below.

Embedded component in MDX

Niall Quinn

Niall Quinn

Designer & Developer

I'm passionate about creating meaningful digital experiences through thoughtful design and innovative technology. Through this journal, I share insights and lessons learned along the way.