Skip to content

Instantly share code, notes, and snippets.

@CodeMyUI
Created June 26, 2017 15:14
Show Gist options
  • Star 6 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save CodeMyUI/36a6ab97f638a9253652160fbb35829e to your computer and use it in GitHub Desktop.
Save CodeMyUI/36a6ab97f638a9253652160fbb35829e to your computer and use it in GitHub Desktop.
Lazy Load Images
<ul class="card-list">
<li class="card">
<a class="card-image" href="https://michellezauner.bandcamp.com/album/psychopomp-2" target="_blank" style="background-image: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/psychopomp-100.jpg);" data-image-full="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/psychopomp-500.jpg">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/psychopomp-100.jpg" alt="Psychopomp" />
</a>
<a class="card-description" href="https://michellezauner.bandcamp.com/album/psychopomp-2" target="_blank">
<h2>Psychopomp</h2>
<p>Japanese Breakfast</p>
</a>
</li>
<li class="card">
<a class="card-image" href="https://inlovewithaghost.bandcamp.com/album/lets-go" target="_blank" style="background-image: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/lets-go-100.jpg);" data-image-full="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/lets-go-500.jpg">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/lets-go-100.jpg" alt="let's go" />
</a>
<a class="card-description" href="https://inlovewithaghost.bandcamp.com/album/lets-go" target="_blank">
<h2>let's go</h2>
<p>In Love With A Ghost</p>
</a>
</li>
<li class="card">
<a class="card-image" href="https://vulfpeck.bandcamp.com/album/the-beautiful-game" target="_blank" style="background-image: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/beautiful-game-100.jpg);" data-image-full="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/beautiful-game-500.jpg">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/beautiful-game-100.jpg" alt="The Beautiful Game" />
</a>
<a class="card-description" href="https://vulfpeck.bandcamp.com/album/the-beautiful-game" target="_blank">
<h2>The Beautiful Game</h2>
<p>Vulfpeck</p>
</a>
</li>
<li class="card">
<a class="card-image" href="https://convergecult.bandcamp.com/album/jane-doe" target="_blank" style="background-image: url(https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/jane-doe-100.jpg);" data-image-full="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/jane-doe-500.jpg">
<img src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/310408/jane-doe-100.jpg" alt="Jane Doe" />
</a>
<a class="card-description" href="https://convergecult.bandcamp.com/album/jane-doe" target="_blank">
<h2>Jane Doe</h2>
<p>Converge</p>
</a>
</li>
</ul>
// This is "probably" IE9 compatible but will need some fallbacks for IE8
// - (event listeners, forEach loop)
// wait for the entire page to finish loading
window.addEventListener('load', function() {
// setTimeout to simulate the delay from a real page load
setTimeout(lazyLoad, 1000);
});
function lazyLoad() {
var card_images = document.querySelectorAll('.card-image');
// loop over each card image
card_images.forEach(function(card_image) {
var image_url = card_image.getAttribute('data-image-full');
var content_image = card_image.querySelector('img');
// change the src of the content image to load the new high res photo
content_image.src = image_url;
// listen for load event when the new photo is finished loading
content_image.addEventListener('load', function() {
// swap out the visible background image with the new fully downloaded photo
card_image.style.backgroundImage = 'url(' + image_url + ')';
// add a class to remove the blur filter to smoothly transition the image change
card_image.className = card_image.className + ' is-loaded';
});
});
}
/* Lazy Load Styles */
.card-image {
display: block;
min-height: 20rem; /* layout hack */
background: #fff center center no-repeat;
background-size: cover;
filter: blur(3px); /* blur the lowres image */
}
.card-image > img {
display: block;
width: 100%;
opacity: 0; /* visually hide the img element */
}
.card-image.is-loaded {
filter: none; /* remove the blur on fullres image */
transition: filter 1s;
}
/* Layout Styles */
html, body {
width: 100%;
height: 100%;
margin: 0;
font-size: 16px;
font-family: sans-serif;
}
.card-list {
display: block;
margin: 1rem auto;
padding: 0;
font-size: 0;
text-align: center;
list-style: none;
}
.card {
display: inline-block;
width: 90%;
max-width: 20rem;
margin: 1rem;
font-size: 1rem;
text-decoration: none;
box-shadow: 0 0 3rem -1rem rgba(0,0,0,0.5);
transition: transform 0.1s ease-in-out, box-shadow 0.1s;
}
.card:hover {
transform: translateY(-0.5rem) scale(1.0125);
box-shadow: 0 0.5em 3rem -1rem rgba(0,0,0,0.5);
}
.card-description {
display: block;
padding: 1em 0.5em;
color: #515151;
text-decoration: none;
}
.card-description > h2 {
margin: 0 0 0.5em;
}
.card-description > p {
margin: 0;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment