Skip to content

Instantly share code, notes, and snippets.

@mtmckenna
Created January 28, 2016 06:12
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mtmckenna/9b61bf6be19a98774d14 to your computer and use it in GitHub Desktop.
Save mtmckenna/9b61bf6be19a98774d14 to your computer and use it in GitHub Desktop.
Pizza vs. Memory Leaks Demo
<!DOCTYPE html>
<title>Pizza vs. Memory Leaks</title>
<body>
<style>
body {
background-color: #ffffcc;
color: #000;
font-size: 30px;
text-align: center;
}
img {
image-rendering: pixelated;
height: 100px;
padding: 5px;
cursor: pointer;
}
.pizza {
margin-bottom: 5px;
}
</style>
<div class="slices-eaten">
Pizza vs. Memory Leaks!
</div>
<div>
<button onclick="createPizza()">Make a pizza!</button>
</div>
<script>
var slices = [];
function createPizza() {
for (var i = 0; i < 100; i++) {
slices.push(addSliceToDom());
}
updateSlicesEaten(slices.length);
}
function addSliceToDom() {
var slice = document.createElement("img");
slice.src = "";
// Add rando super long string to the element so the memory leak is obvious
slice.data = new Array(100000).join("Slice");
var body = document.getElementsByTagName("body")[0];
body.appendChild(slice);
window.setTimeout(function() {
body.removeChild(slice);
}, Math.random() * 1000);
return slice;
}
function updateSlicesEaten(numberOfSlices) {
document.getElementsByClassName("slices-eaten")[0].innerText = numberOfSlices + " slices were eaten.";
}
</script>
</body>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment