Every web developer knows the struggle with image optimization. You want your images to look good, but large file sizes slow down your sites and hurt the user experience. JPEG and WebP have been popular choices for image compression, but they have limitations when it comes to achieving high compression without sacrificing image quality. AVIF offers a solution to this problem.
Built on the AV1 video codec by the Alliance for Open Media, it gives us much better compression without the quality loss we're used to seeing in highly compressed images.
Now that Appwrite supports AVIF in Storage, you can start using it in your projects. This matters because you can reduce image sizes by 50% or more compared to JPEG, while keeping the same visual quality. And for users with browsers that don't support AVIF yet, you can easily fall back to other formats.
Let's learn how AVIF works in Appwrite and look at some real implementation examples.
What makes AVIF different?
AVIF brings several technical improvements to image compression:
Achieves better compression than JPEG and WebP while maintaining quality
Preserves more image detail at similar file sizes
Includes alpha channel for transparency
Works with wide color gamut (supports both HDR and standard color ranges)
Supports animations and image sequences
Supported by major browsers including Chrome and Firefox
Implementation in Appwrite
Appwrite's Storage service provides three main ways to work with AVIF:
Direct AVIF file storage
On-demand conversion from other formats
Format-specific delivery based on browser support
Let's examine each approach in detail.
Direct AVIF upload
You can upload AVIF images to Appwrite Storage just like any other supported image format.
Here's an example using the Web SDK:
import { Client, Storage, ID } from "appwrite";
const client = new Client()
.setEndpoint('<https://cloud.appwrite.io/v1>')
.setProject('<PROJECT_ID>');
const storage = new Storage(client);
// Upload an AVIF file
const promise = storage.createFile(
'<BUCKET_ID>',
ID.unique(),
document.getElementById('uploader').files[0]
);
promise.then(function (response) {
console.log(response);
}, function (error) {
console.log(error);
});
This code handles file upload through a standard form input. The Storage service accepts AVIF files just like any other supported image format, with no special handling required at the upload stage.
Converting images to AVIF
Appwrite's Storage service can convert your existing images to AVIF format on demand. This means you can transform JPEGs, PNGs, and other formats to AVIF without preprocessing them.
Here's how to implement the conversion:
import { Client, Storage, ImageGravity, ImageFormat } from "appwrite";
const client = new Client()
.setEndpoint('<https://cloud.appwrite.io/v1>')
.setProject('<PROJECT_ID>');
const storage = new Storage(client);
const result = storage.getFilePreview(
'<BUCKET_ID>', // bucketId
'<FILE_ID>', // fileId
2000, // width
0, // height (maintain aspect ratio)
ImageGravity.Center, // gravity
100, // quality
0, // borderWidth
'', // borderColor
0, // borderRadius
1, // opacity
0, // rotation
'', // background
ImageFormat.Avif // output format
);
The quality parameter in getFilePreview ranges from 0-100. AVIF's compression algorithm processes different image types (photographs, illustrations, UI elements) with varying efficiency, so quality settings need to be tested for your specific use case.
The ImageGravity enum determines how images are cropped or positioned during resizing - Center maintains focus on the middle of the image.
The ImageFormat enum specifies the output format, with options including Avif, Webp, Jpg, and Png.
Browser compatibility detection
To ensure the best experience for all users, you should check for AVIF support before serving AVIF images.
Here's a simple way to detect AVIF support:
async function isAvifSupported() {
const avif = new Image();
return new Promise((resolve) => {
avif.onload = () => resolve(true);
avif.onerror = () => resolve(false);
avif.src = "";
});
}
// Usage
if (await isAvifSupported()) {
// Serve AVIF images
} else {
// Fallback to WebP or JPEG
}
This code tries to load a tiny base64-encoded AVIF image in the browser. If the image loads successfully (onload), the browser supports AVIF. If it fails to load (onerror), it means the browser can't decode AVIF images and we need to use a fallback format
Implementing a format fallback
We can use the isAvifSupported function to implement progressive enhancement for image loading. This means using a baseline format (in this case, WebP) and using AVIF for browsers that support it.
Here's an example:
const storage = new Storage(client);
async function getOptimizedImageUrl(bucketId, fileId) {
const format = await isAvifSupported() ? ImageFormat.Avif : ImageFormat.WebP;
return storage.getFilePreview(
bucketId,
fileId,
1200, // width
0, // height
'center', // gravity
90, // quality
0, // border width
'', // border color
0, // border radius
1, // opacity
0, // rotation
'', // background
format // output format
);
}
Notice that the format variable falls back to WebP if the browser doesn't support AVIF. I've used WebP because it's now widely supported. However, you can choose to fallback to JPEG for an even wider range of compatibility.
Best practices for using AVIF in Appwrite Storage
When working with AVIF in Appwrite Storage, consider these best practices:
Progressive enhancement: Always implement fallbacks for browsers that don't support AVIF.
Quality settings: AVIF provides good quality even at lower settings. Start with a quality setting of 75-85 and adjust based on your needs.
Responsive images: Use appropriate image dimensions for different screen sizes to optimize bandwidth usage.
Performance monitoring: Monitor your application's performance metrics after implementing AVIF to ensure it provides the expected benefits.
Lazy loading: Consider implementing lazy loading for AVIF images to further optimize page load performance.
Conclusion
AVIF support in Appwrite Storage is a practical way to make your apps faster without compromising on image quality. The code to implement it is straightforward, and the benefits are real - especially for image-heavy applications.
Start with a few test images, measure the results, and scale up from there. Your users will get faster load times, and you'll cut down on bandwidth costs.
For more details on handling images in Appwrite, check out the Storage documentation.