CodePen

HTML

            
              
<div class="img">
  <label>source &lt;img&gt;</label>
  <img class="element from" src="" alt="" />
</div>
    
<div class="canvas">
  <label>&lt;canvas&gt;</label>
  <canvas class="element"></canvas>
</div>
    
<div class="img">
  <label>new &lt;img&gt;</label>
  <img class="element to" src>
</div>
    
            
          
!
via HTML Inspector

CSS

            
              body {
  margin: 10px 30px;
}

div {
  display: block;
  float: left;
  margin: 20px;
}

label {
  display: block;
  text-transform: uppercase;
  font-family: monospace;
  font-size: 20px;
  margin-bottom: 2px;
}

.canvas {
  color: red;
}

.img {
  color: blue;
}

.canvas .element {
  border: 2px solid red;
}

.img .element {
  border: 2px solid blue;
}
            
          
!
? ?
? ?
Must be a valid URL.
+ add another resource
via CSS Lint

JS

            
              function base64ToBlobSync (base64, contentType) {
  contentType = contentType || base64.match(/^data\:([^\;]+)\;base64,/mi)[1] || ''; // e.g. 'data:image/jpeg;base64,...' => 'image/jpeg'
  base64 = base64.replace(/^data\:([^\;]+)\;base64,/gmi, '');
  
  var binary = atob(base64);
  var len = binary.length;
  var buffer = new ArrayBuffer(len);
  var view = new Uint8Array(buffer);
  
  for (var i = 0; i < len; i++) {
    view[i] = binary.charCodeAt(i);
  }
  var blob = new Blob([view], {type: contentType});
  
  return blob;
}

function blobToBase64Async (blob, callback) {
  var reader = new FileReader();
  reader.onload = function(e){
    callback(e.target.result);
  };
  reader.readAsDataURL(blob);
};

function objectURLToBlob(object_url, callback) {
  var xhr = new XMLHttpRequest();
  xhr.open('GET', object_url, true);
  xhr.responseType = 'blob';
  xhr.onload = function(e) {
    var blob;
    if (this.status == 200) {
      blob = this.response;
    }
    callback(blob);
  };
  xhr.send();
}

var scale = 0.4;

var img = document.querySelector('img.from');
var canvas = document.querySelector('canvas');
var ctx = canvas.getContext('2d');
var img2 = document.querySelector('img.to');

var data_uri, blob, object_url, data_uri_2, blob_2;

function drawImage () {
  canvas.width = img.width * scale;
  canvas.height = img.height * scale;
  
  ctx.drawImage(img, 0, 0, img.width * scale, img.height * scale);
  
  data_uri = canvas.toDataURL();
  
  console.log("Data URL: ", data_uri);
  
  blob = base64ToBlobSync(data_uri);
 
  console.log("Blob: ", blob);
  
  object_url = URL.createObjectURL(blob);
  
  console.log("Object URL: ", object_url);
  
  blobToBase64Async(blob, function(base64) {
    data_uri_2 = base64;
    
    console.log("Blob => Data URI: ", data_uri_2);
  });
  
  objectURLToBlob(object_url, function(blob) {
    blob_2 = blob;
    
    console.log("Object URL => Blob: ", blob_2);
  });
  
  img2.src = object_url;
};

img.onload = drawImage;

if (img.complete) {
  drawImage();
}
            
          
!
Must be a valid URL.
+ add another resource
via JS Hint
Loading ..................