Skip to content

Instantly share code, notes, and snippets.

@byeblogs
Last active May 25, 2021 11:40
Show Gist options
  • Save byeblogs/96031b2c77e66b36ffdb608774ead6ba to your computer and use it in GitHub Desktop.
Save byeblogs/96031b2c77e66b36ffdb608774ead6ba to your computer and use it in GitHub Desktop.
Blur Image Before Loaded
HTML
<div class="placeholder" data-large="https://cdn-images-1.medium.com/max/1800/1*sg-uLNm73whmdOgKlrQdZA.jpeg">
<img src="https://cdn-images-1.medium.com/freeze/max/27/1*sg-uLNm73whmdOgKlrQdZA.jpeg?q=20" class="img-small">
<div style="padding-bottom: 66.6%;"></div>
</div>
CSS
.placeholder {
background-color: #f6f6f6;
background-size: cover;
background-repeat: no-repeat;
position: relative;
overflow: hidden;
}
.placeholder img {
position: absolute;
opacity: 0;
top: 0;
left: 0;
width: 100%;
transition: opacity 1s linear;
}
.placeholder img.loaded {
opacity: 1;
}
.img-small {
filter: blur(50px);
/* this is needed so Safari keeps sharp edges */
transform: scale(1);
}
JS
window.onload = function() {
var placeholder = document.querySelector('.placeholder'),
small = placeholder.querySelector('.img-small')
// 1: load small image and show it
var img = new Image();
img.src = small.src;
img.onload = function () {
small.classList.add('loaded');
};
// 2: load large image
var imgLarge = new Image();
imgLarge.src = placeholder.dataset.large;
imgLarge.onload = function () {
imgLarge.classList.add('loaded');
};
placeholder.appendChild(imgLarge);
}
#Source Codepen : http://codepen.io/jmperez/pen/yYjPER
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment