Skip to content Skip to sidebar Skip to footer

Enlarge An Image From Zero To Full Size On Image Load

I'm placing images of a bubble randomly and I want to simulate the effect of making the bubble by enlarging the image from zero to full size. I'm using CSS transform:scale(); but I

Solution 1:

You can add a class to the image when it finishes loading, and specify proper transition and transform rules in CSS.

$("img").load(function() {
  $(this).addClass("loaded");
});
img {
  transition: transform 1s;
  transform: scaleX(0) scaleY(0);
}
img.loaded {
  transform: scaleX(1) scaleY(1);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<img src="http://lorempixel.com/600/600/">

Solution 2:

Here are two ways which doesn't require jQuery.

This way is preferable:

var pics = document.querySelectorAll(".zoom");
for (var i = 0; i < pics.length; i++) {
    pics[i].addEventListener('load', function() {

      this.className += " loaded";

      // use this method if to support newer browsers only
      //this.classList.add("loaded");

    }, false);
}
img {
  transition: transform .5s;
  transform: scale(0,0);  
}
img.loaded {
  transform: scale(1,1);  
}
<img src="http://lorempixel.com/200/200/" class="zoom">

and this could be used when the amount of images is limited:

function imgresize(el) {
  el.className += " loaded";
}
img {
  transition: transform .5s;
  transform: scale(0,0);  
}
img.loaded {
  transform: scale(1,1);  
}
<img src="http://lorempixel.com/200/200/" onload="imgresize(this);">

Solution 3:

You can try onload() function to do certain tasks that only happend when something is loaded.

i.e;

$('img').on('load',function(){
   alert('image loaded');
}

Post a Comment for "Enlarge An Image From Zero To Full Size On Image Load"