D3.js
in data visualization
Data-Driven Documents
- library designed for SVG and HTML
- does not work for Canvas (until it's not a document)
- it's relatively low-level tool - don't even touch it if you don't need more than simple chart
D3 can replace
- Handlebars, Moustache
- React
- jQuery
- Raphaël :)
D3 (alone) cannot replace
- Angular, Ember... *
- Highcharts / Chart.js
* put name of framework you use here
How is it different?
Declarative approach
No templates!
Data-binding
Animations
Helpers
- math functions
- time functions
- data parsers
- scales
- axes
- geographic data
- 2D graphics
- standard layouts
- and much more
The only thing you need is...
to understand.
Data-binding and selections
Layouts
-
encapsulate a strategy for laying out data elements visually
- cover common use cases: piechart, tree, histogram, pack
- layout does not draw anything, just transform data
Layouts
Behaviors
- encapsulate a complex set of low-level DOM interactions
- does not render anything
- two built-in: zoom & drag
Components
- reusable chunks of the view
- may expose high-level events
- may transform data
Components
Caveats
Tricky Transitions
Sneaky Selections
Evil Event
Horrible Handlers
Further reading
it's over
Thank you!
Eryk Napierała
D3.js in data visualization
By Eryk Napierała
D3.js in data visualization
- 2,042