Lexington has been awarded a grant from Astro, to celebrate. Get a 30% discount. Apply code LEXINGTON30 at checkout.
Let’s say you have a collection of images that you want to display in a gallery. That’s what this tutorial is all about.
Image galleries are a way to display a collection of images in a visually appealing way. They are used to showcase a variety of images or to provide a preview of a product or service.
and so on and so forth. There’s a lot of different use cases for image galleries, and the possibilities are endless.
Understanding the code:
x-data="{ currentImage: null }"
: This is the data that will be used to store the current image.x-init="()
: This is the initialization code that will be executed when the component is first rendered.window.addEventListener('keydown', (event)
: This is the event listener that will be added to the window object.if (event.key === 'Escape')
: This is the condition that will be checked when the Escape key is pressed.currentImage = null;
: This is the code that will be executed when the Escape key is pressed.x-on:click="currentImage = '/path-to-your/image.png'"
: This is the event listener that will be added to the image elements.src="/path-to-your/image.png"
: This is the where you will put the path to your image.x-on:click="currentImage = null"
: This is the event listener that will be added to the close button.@click.away="currentImage = null"
: This is the event listener that will be added to the close button.:src="currentImage"
: This is the attribute that will be added to the image element.Classes are removed for brevity, but I’ll keep those classes relevant to the tutorial.
<div
x-data="{ currentImage: null }"
x-init="() => {
window.addEventListener('keydown', (event) => {
if (event.key === 'Escape') {
currentImage = null;
}
});
}">
<div class="grid grid-cols-3 gap-4">
<div
x-on:click="currentImage = '/path-to/image-1.png'">
<img
src="/path-to/image-1.png"
alt="Image 1"
/>
</div>
<div
x-on:click="currentImage = '/path-to/image-2.png'">
<img
src="/path-to/image-2.png"
alt="Image 2"
/>
</div>
<div
x-on:click="currentImage = '/path-to/image-3.png'">
<img
src="/path-to/image-3.png"
alt="Image 3"
/>
</div>
<!-- Add more image placeholders as needed -->
</div>
<!-- Modal -->
<div
x-show="currentImage"
role="dialog"
aria-modal="true"
aria-labelledby="modal-title">
<div
@click.away="currentImage = null"
tabindex="-1"
aria-labelledby="modal-title"
aria-describedby="modal-description">
<button
@click="currentImage = null"
>Close</button
>
<img
:src="currentImage"
alt="Full Size Image"
/>
</div>
</div>
</div>
<div
@click.away="currentImage = null"
>
<img
:src="currentImage"
/>
</div>
</div>
</div>
This is a simple image gallery that can be used for any type of content, such as products, services, or blog posts. But before using it make sure to make it fully accessible and responsive. You can also add more features to the gallery, such as zooming in and out, or adding a caption to each image, a button to go back to the previous image, to close the modal, and so on.
Hope you enjoyed this tutorial and have a great day!
/Michael Andreuzza
Get access to all themes
Unlock all themes for $199 for forever! Includes lifetime updates,
new themes, unlimited projects, and support
— No subscription
needed.