
Product
Introducing Reports: An Extensible Reporting Framework for Socket Data
Explore exportable charts for vulnerabilities, dependencies, and usage with Reports, Socket’s new extensible reporting framework.
progressive-picture
Advanced tools
This 700 bytes (compressed) library enhances
Picture Elementswith Progressive Image Loading and thus improves the initial time of images being displayed. You can find out more from the blog post.
$ npm install progressive-picture
import { observe } from "progressive-picture";
observe();
<script type="module">
import { observe } from "https://unpkg.com/progressive-picture";
observe();
</script>
picture > img {
display: block;
max-width: 100%;
height: auto;
filter: blur(0);
transition: filter 0.7s ease-in;
}
picture > img[data-src] {
filter: blur(3px);
}
picture > img.img-progressive {
width: auto;
}
or for mostly full-bleed images
picture {
@apply relative;
& img {
@apply block h-auto max-w-full;
& .img-progressive {
@apply w-auto;
}
}
&::after {
@apply pointer-events-none absolute inset-0 backdrop-blur-none duration-300 ease-in-out content-[""] motion-safe:transition-[backdrop-filter];
}
&:has(img[data-src])::after {
@apply backdrop-blur-xs;
}
}
<picture>
<source srcset="eu.preview.webp" data-src="eu.webp" type="image/webp" />
<source srcset="eu.preview.jpg" data-src="eu.jpg" type="image/jpg" />
<img
src="eu.preview.jpg"
data-src="eu.jpg"
loading="lazy"
width="500"
height="750"
alt=""
data-alt="Eukalyptus"
/>
</picture>
https://lazy-load-picture.netlify.app/
https://lazy-load-picture.netlify.app/masonry.html
The srcset of <source> and the src of <img> has to be filled with the URI for the low-quality image (or in case of the <source> element: a srcset of low quality preview pictures. The data-src holds the high-quality image(s) and will be replaced once it has been loaded.
Also, there is a data-alt Attribute that can be applied as alt, once the Image was replaced. This fixes the inelegance of displaying text before an image appears.
While this library is useful on the Web, optimizing the image correctly in the build step is the other side of the coin. This plugin snowpack-plugin-sharp could be helpful in this case.
FAQs
Native Lazy Loaded Picture Element with Progressive Image Change
We found that progressive-picture demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Explore exportable charts for vulnerabilities, dependencies, and usage with Reports, Socket’s new extensible reporting framework.

Product
Socket for Jira lets teams turn alerts into Jira tickets with manual creation, automated ticketing rules, and two-way sync.

Company News
Socket won two 2026 Reppy Awards from RepVue, ranking in the top 5% of all sales orgs. AE Alexandra Lister shares what it's like to grow a sales career here.