http://bost.ocks.org/mike/constancy/javascript
http://corner.squareup.com/2012/04/building-analytics.htmlhtml
To achieve object constancy with D3.js, specify a key function as the second argument to selection.data. This function takes a data point as input and returns a corresponding key: a string, such as a name, that uniquely identifies the data point.java
Key functions can be useful for improving performance independent of transitions. For example, if you filter a large table, you can use a key function to reduce the number of DOM modifications: reorder DOM elements in the update selection rather than regenerating themgit
Transitions between unrelated datasets or dimensions (e.g., from temperature to stock price) should use a simpler cross-fade or cut rather than gratuitous, nonsensical movement.github
d3.select()app
d3.selectAll().data([], function(){})ide
d3.transition(element)
ui
selectAll + data + enter + append spa
Element.style("fill", function(data, index){})code
Element.attr("cx", function(data, index){})