I am trying to optimize the image by formatting that to avif. But some of the browser's are not supporting avif.
So I created a utility function like this
function isAvifSupported() {
let returnValue;
const avif = new Image();
avif.src =
"";
avif.onload = function () {
returnValue = true
};
return returnValue;
}
but when I try to call this function it always returns undefined. But when I use the function that has been provided in avif site. it works fine. Below is the code for it
function AddClass(class) { document.documentElement.classList.add(class) };
var avif = new Image();
avif.src = "";
avif.onload = function () { AddClass("avif") };
avif.onerror = function () {
var webp = new Image();
webp.src = "";
webp.onload = function () { AddClass("webp") }
}
But the above-defined function adds the css at the top level of dom. Instead of adding the class, It has to return true or false. So that i am able to handle that easily like this.
let updatedImageUrl = isAvifSupported() ? `${imageUrl}?fm=avif` ? imageUrl
But I don't know, how to fix this. Please recommend a solution.