Dynamically import images
Local images must be imported into .astro files in order to display them. There will be times where you will want or need to dynamically import the image paths of your images instead of explicitly importing each individual image.
In this recipe, you will learn how to dynamically import your images using Vite’s import.meta.glob function. You will build a card component that displays the name, age, and photo of a person.
Recipe
Section titled Recipe- Create a new assetsfolder under thesrcdirectory and add your images inside that new folder.
- Directorysrc/- Directoryassets/- avatar-1.jpg
- avatar-2.png
- avatar-3.jpeg
 
 
assets is a popular folder name convention for placing images but you are free to name the folder whatever you like.
- 
Create a new Astro component for your card and import the <Image />component.src/components/MyCustomCardComponent.astro ---import { Image } from 'astro:assets';---
- 
Specify the propsthat your component will receive in order to display the necessary information on each card. You can optionally define their types, if you are using TypeScript in your project.src/components/MyCustomCardComponent.astro ---import { Image } from 'astro:assets';interface Props {imagePath: string;altText: string;name: string;age: number;}const { imagePath, altText, name, age } = Astro.props;---
- 
Create a new imagesvariable and use theimport.meta.globfunction which returns an object of all of the image paths inside theassetsfolder.src/components/MyCustomCardComponent.astro ---import { Image } from 'astro:assets';interface Props {imagePath: string;altText: string;name: string;age: number;}const { imagePath, altText, name, age } = Astro.props;const images = import.meta.glob('/src/assets/*.{jpeg,jpg,png,gif}')---
- 
Use the props to create the markup for your card component. src/components/MyCustomCardComponent.astro ---import { Image } from 'astro:assets';interface Props {imagePath: string;altText: string;name: string;age: number;}const { imagePath, altText, name, age } = Astro.props;// Type: Record<string, () => Promise<{default: ImageMetadata}>>const images = import.meta.glob('/src/assets/*.{jpeg,jpg,png,gif}')---<div class="card"><h2>{name}</h2><p>Age: {age}</p><Image src={} alt={altText} /></div>
- 
Inside the srcattribute, pass in theimagesobject and use bracket notation for the image path. Then make sure to invoke the glob function.src/components/MyCustomCardComponent.astro ---import { Image } from 'astro:assets';interface Props {imagePath: string;altText: string;name: string;age: number;}const { imagePath, altText, name, age } = Astro.props;const images = import.meta.glob('/src/assets/*.{jpeg,jpg,png,gif}')---<div class="card"><h2>{name}</h2><p>Age: {age}</p><Image src={images[imagePath]()} alt={altText} /></div>
images is an object that contains all of the image paths inside the assets folder.
const images = {  './assets/avatar-1.jpg': () => import('./assets/avatar-1.jpg'),  './assets/avatar-2.png': () => import('./assets/avatar-2.png'),  './assets/avatar-3.jpeg': () => import('./assets/avatar-3.jpeg')}The imagePath prop is a string that contains the path to the image that you want to display. The import.meta.glob() is doing the work of finding the image path that matches the imagePath prop and handling the import for you.
- 
Import and use the card component inside an Astro page, passing in the values for the props.src/pages/index.astro ---import MyCustomCardComponent from '../components/MyCustomCardComponent.astro';---<MyCustomCardComponentimagePath="/src/assets/avatar-1.jpg"altText="A headshot of Priya against a brick wall background."name="Priya"age={25}/>