summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWilson Page <wilsonpage@me.com>2013-10-08 04:02:28 -0700
committerWilson Page <wilsonpage@me.com>2013-10-08 04:02:28 -0700
commit6051b8cd7b188a16ef830e9ec088bcc3dcd02172 (patch)
tree9b0996950ee829eee734d7fd51b06e9b705c28a5
parentbacebe96852dab96c91e11d9899b02048293cca9 (diff)
parent6ef5076046f82fd71a7334a2be40af8d06367dcb (diff)
downloadfastdom-6051b8cd7b188a16ef830e9ec088bcc3dcd02172.zip
fastdom-6051b8cd7b188a16ef830e9ec088bcc3dcd02172.tar.gz
fastdom-6051b8cd7b188a16ef830e9ec088bcc3dcd02172.tar.bz2
Merge pull request #26 from georgecrawford/gh-pages
Add introductory paragraph to explain the animation demo
-rw-r--r--examples/animation.html38
1 files changed, 26 insertions, 12 deletions
diff --git a/examples/animation.html b/examples/animation.html
index 4e03fb6..b8dfeb7 100644
--- a/examples/animation.html
+++ b/examples/animation.html
@@ -7,8 +7,8 @@
<body>
<style>
- .mover {
+ .mover {
/* Stolen shamelessly from https://developers.google.com/chrome-developer-tools/docs/demos/too-much-layout/ */
background: url("");
height: 100px;
@@ -20,40 +20,54 @@
color: red;
}
+ .intro {
+ margin: 10px;
+ background: rgb(214, 213, 213);
+ border: 1px solid grey;
+ padding: 10px;
+ }
+
</style>
+ <div class="intro">An adaptation of the demo from the Google Developers article <a href="https://developers.google.com/chrome-developer-tools/docs/demos/too-much-layout/">Diagnosing forced synchronous layouts</a>. In the article, forced synchronous layouts are fixed by simply <em>not doing any reads at all</em>. Rather than this extreme solution, which will not be appropriate for many use cases, we instead use <strong>fastdom</strong> to intelligently defer and batch the DOM reads and writes, and get similar performance gains as a result.</div>
<label>Number of elements <input id="count" type="text" value="400" /></label>
<button id="sync" class="active">Forced synchronous layout</button>
<button id="async">Run with FastDom</button>
- <button id="noread">Avoid DOM read</button>
+ <button id="noread">No DOM reads</button>
<button id="toggle">Start</button>
<div id='test'></div>
<script>
- var moveMethod = 'sync',
- count = document.getElementById('count'),
- test = document.getElementById('test'),
+ var moveMethod = 'sync',
+ count = document.getElementById('count'),
+ test = document.getElementById('test'),
timestamp, raf, movers;
var mover = {
sync: function(m) {
- mover.setLeft(m, movers[m].offsetTop);
+
+ // Read the top offset, and use that for the left position
+ mover.setLeft(movers[m], movers[m].offsetTop);
},
async: function(m) {
+
+ // Use fastdom to batch the reads and writes with exactly the same code as the 'sync' routine
fastdom.read(function() {
var top = movers[m].offsetTop;
fastdom.write(function() {
- mover.setLeft(m, top);
+ mover.setLeft(movers[m], top);
});
});
},
noread: function(m) {
- mover.setLeft(m, m);
+
+ // Simply use the array index as the top value, so no DOM read is required
+ mover.setLeft(movers[m], m);
},
- setLeft: function(m, top) {
- movers[m].style.left = ((Math.sin(top + timestamp/1000)+1) * 500) + 'px';
+ setLeft: function(mover, top) {
+ mover.style.left = ((Math.sin(top + timestamp/1000) + 1) * 500) + 'px';
}
};
@@ -87,9 +101,9 @@
test.innerHTML = html;
movers = test.querySelectorAll('.mover');
- movers[0].style.top = '50px';
+ movers[0].style.top = '150px';
for (var m = 1; m < movers.length; m++) {
- movers[m].style.top = (m * 20) + 'px';
+ movers[m].style.top = (m * 20) + 150 + 'px';
}
raf = window.requestAnimationFrame(update);