Add lazy loading of images in Jekyll posts
Normally you define images with ![]()
in markdown files. But jekyll also
provides a way to adding custom attributes to tags with {:attr="value"}
.
If you have lots of posts this command will append `` to all images in all your markdown files.
data:image/s3,"s3://crabby-images/2e67f/2e67fb4e245fe4f93ea18bd59c6773d45ebf78e7" alt="image-title"
will become
data:image/s3,"s3://crabby-images/2e67f/2e67fb4e245fe4f93ea18bd59c6773d45ebf78e7" alt="image-title"
Shell line bellow. Go into the folder where your posts are (probably _posts
).
find . -type f -name "*.md" -exec sed -i -E 's/(\!\[.*\]\((.*?)\))$/\1/' {} \;
Under the hood this adds loading="lazy"
to HTML img
nodes.
That is about it.