D3.js: Difference between revisions
No edit summary |
m Fixed broken link |
||
Line 35: | Line 35: | ||
}} |
}} |
||
{{Portal|Free software}} |
{{Portal|Free software}} |
||
'''D3.js''' (or just '''D3''' for '''Data-Driven Documents''') is a [[JavaScript]] library for producing dynamic, interactive [[data visualization]]s in [[web browser]]s. It makes use of the widely implemented [[Scalable Vector Graphics|SVG]], [[HTML5]], and [[Cascading Style Sheets|CSS]] standards. It is the successor to the earlier Protovis framework.<ref>{{citation |url=https://mbostock.github.com/d3/tutorial/protovis.html |title=For Protovis Users|website=Mbostock.github.com|accessdate=August 18, 2012 }}</ref> In contrast to many other libraries, D3.js allows great control over the final visual result.<ref name="Viau_2012/06">{{citation |url= |
'''D3.js''' (or just '''D3''' for '''Data-Driven Documents''') is a [[JavaScript]] library for producing dynamic, interactive [[data visualization]]s in [[web browser]]s. It makes use of the widely implemented [[Scalable Vector Graphics|SVG]], [[HTML5]], and [[Cascading Style Sheets|CSS]] standards. It is the successor to the earlier Protovis framework.<ref>{{citation |url=https://mbostock.github.com/d3/tutorial/protovis.html |title=For Protovis Users|website=Mbostock.github.com|accessdate=August 18, 2012 }}</ref> In contrast to many other libraries, D3.js allows great control over the final visual result.<ref name="Viau_2012/06">{{citation |url=https://www.datameer.com/blog/whats-behind-our-business-infographics-designer-d3-js-of-course-2/ |title=What’s behind our Business Infographics Designer? D3.js of course |last=Viau |first=Christophe |work=[[Datameer]]'s blog |date=June 26, 2012 |accessdate=August 18, 2012 }}</ref> Its development was noted in 2011,<ref>{{citation |url=https://books.google.com/books?id=nTpjoNgJQOMC |title=Making Sense of Data III: A Practical Guide to Designing Interactive Data Visualizations |first1=Glenn J. |last1=Myatt |first2= Wayne P. |last2=Johnson |chapter-url=https://books.google.com/books?id=nTpjoNgJQOMC&pg=SL1-PA2 |chapter=5.10 Further reading |page=A–2 |publisher=[[John Wiley & Sons]] |place=Hoboken, New Jersey |date=September 2011 |isbn=978-0-470-53649-0|accessdate=January 23, 2013 }}</ref> as version 2.0.0 was released in August 2011.<ref>{{citation |url=https://github.com/d3/d3/wiki/Release-Notes |title=Release Notes |work=D3.js |accessdate=August 22, 2012 }}</ref> |
||
D3.js is used on hundreds of thousands of websites.<ref>https://www.wappalyzer.com/technologies/d3</ref> Some popular uses include creating interactive graphics for online news websites, information dashboards for viewing data, and producing maps from [[GIS]] [[web mapping|map making]] data. In addition, the exportable nature of SVG enables graphics created by D3 to be used in print publications. |
D3.js is used on hundreds of thousands of websites.<ref>https://www.wappalyzer.com/technologies/d3</ref> Some popular uses include creating interactive graphics for online news websites, information dashboards for viewing data, and producing maps from [[GIS]] [[web mapping|map making]] data. In addition, the exportable nature of SVG enables graphics created by D3 to be used in print publications. |
Revision as of 10:49, 19 June 2018
Developer(s) | Mike Bostock, Jason Davies, Jeffrey Heer, Vadim Ogievetsky, and community |
---|---|
Initial release | 18 February 2011 |
Stable release | 5.1.0
/ 17 April 2018[1] |
Repository | |
Written in | JavaScript |
Type | Data visualization, JavaScript library |
License | BSD |
Website | d3js |
D3.js (or just D3 for Data-Driven Documents) is a JavaScript library for producing dynamic, interactive data visualizations in web browsers. It makes use of the widely implemented SVG, HTML5, and CSS standards. It is the successor to the earlier Protovis framework.[2] In contrast to many other libraries, D3.js allows great control over the final visual result.[3] Its development was noted in 2011,[4] as version 2.0.0 was released in August 2011.[5]
D3.js is used on hundreds of thousands of websites.[6] Some popular uses include creating interactive graphics for online news websites, information dashboards for viewing data, and producing maps from GIS map making data. In addition, the exportable nature of SVG enables graphics created by D3 to be used in print publications.
Context
There have been various previous attempts to bring data visualization to web browsers. The most notable examples were the Prefuse, Flare, and Protovis toolkits, which can all be considered as direct predecessors of D3.js.
Prefuse was a visualization toolkit created in 2005 that required usage of Java, and visualizations were rendered within browsers with a Java plug-in. Flare was a similar toolkit from 2007 that used ActionScript, and required a Flash plug-in for rendering.
In 2009, based on the experience of developing and utilizing Prefuse and Flare, Jeff Heer, Mike Bostock, and Vadim Ogievetsky of Stanford University's Stanford Visualization Group created Protovis, a JavaScript library to generate SVG graphics from data. The library was known to data visualization practitioners and academics.[7]
In 2011, the development of Protovis was stopped to focus on a new project, D3.js. Informed by experiences with Protovis, Bostock, along with Heer and Ogievetsky, developed D3.js to provide a more expressive framework that, at the same time, focuses on web standards and provides improved performance.[8]
Technical principles
Embedded within an HTML webpage, the JavaScript D3.js library uses pre-built JavaScript functions to select elements, create SVG objects, style them, or add transitions, dynamic effects or tooltips to them. These objects can also be widely styled using CSS. Large datasets can be easily bound to SVG objects using simple D3.js functions to generate rich text/graphic charts and diagrams. The data can be in various formats, most commonly JSON, comma-separated values (CSV) or geoJSON, but, if required, JavaScript functions can be written to read other data formats.
Selections
The central principle of D3.js design is to enable the programmer to first use a CSS-style selector to select a given set of Document Object Model (DOM) nodes, then use operators to manipulate them in a similar manner to jQuery.[9] For example, by using D3.js, one may select all HTML <p>...</p>
elements, and then change their text color, e.g. to lavender:
d3.selectAll("p") // select all <p> elements
.style("color", "lavender") // set style "color" to value "lavender"
.attr("class", "squares") // set attribute "class" to value "squares"
.attr("x", 50); // set attribute "x" (horizontal position) to value 50px
The selection can be based on tag (as in the above example), class, identifier, attribute, or place in the hierarchy. Once elements are selected, one can apply operations to them. This includes getting and setting attributes, display texts, and styles (as in the above example). Elements may also be added and removed. This process of modifying, creating and removing HTML elements can be made dependent on data, which is the basic concept of D3.js.
Transitions
By declaring a transition, values for attributes and styles can be smoothly interpolated over a certain time. The following code will make all HTML <p>...</p>
elements on a page gradually change their text color to pink:
d3.selectAll("p") // select all <p> elements
.transition("trans_1") // transition with name "trans_1"
.delay(0) // transition starting 0ms after trigger
.duration(500) // transitioning during 500ms
.ease(d3.easeLinear) // transition easing progression is linear...
.style("color", "pink"); // ... to color:pink
Data-binding
For more advanced uses, loaded data drives the creation of elements. D3.js loads a given dataset, then, for each of its elements, creates an SVG object with associated properties (shape, colors, values) and behaviors (transitions, events).[10][11][12]
// Data
var countriesData = [
{ name:"Ireland", income:53000, life: 78, pop:6378, color: "black"},
{ name:"Norway", income:73000, life: 87, pop:5084, color: "blue" },
{ name:"Tanzania", income:27000, life: 50, pop:3407, color: "grey" }
];
// Create SVG container
var svg = d3.select("#hook").append("svg")
.attr("width", 120)
.attr("height", 120)
.style("background-color", "#D0D0D0");
// Create SVG elements from data
svg.selectAll("circle") // create virtual circle template
.data(countriesData) // bind data
.enter() // for each row in data...
.append("circle") // bind circle & data row such that...
.attr("id", function(d) { return d.name }) // set the circle's id according to the country name
.attr("cx", function(d) { return d.income / 1000 }) // set the circle's horizontal position according to income
.attr("cy", function(d) { return d.life }) // set the circle's vertical position according to life expectancy
.attr("r", function(d) { return d.pop / 1000 *2 }) // set the circle's radius according to country's population
.attr("fill", function(d) { return d.color }); // set the circle's color according to country's color
Generated SVG graphics are designed according to the provided data.
Appending nodes using data
Once a dataset is bound to a document, use of D3.js typically follows a pattern wherein an explicit .enter()
function, an implicit "update," and an explicit .exit()
function is invoked for each item in the bound dataset. Any methods chained after the .enter()
command will be called for each item in the dataset not already represented by a DOM node in the selection (the previous selectAll()
). Likewise, the implicit update function is called on all existing selected nodes for which there is a corresponding item in the dataset, and .exit()
is called on all existing selected nodes that do not have an item in the dataset to bind to them. The D3.js documentation provides several examples of how this works.[13]
API structure
D3.js API contains several hundred functions, and they can be grouped into following logical units:[14]
- Selections
- Transitions
- Arrays
- Math
- Color
- Scales
- SVG
- Time
- Layouts
- Geography
- Geometry
- Behaviors
Maths
- Generation of pseudorandom numbers with normal, log-normal, Bates, and Irwin-Hall distributions.
- Transformations in 2D: translation, rotation, skew, and scaling.
Arrays
D3.js array operations are built to complement existing array support in JavaScript (mutator methods: sort, reverse, splice, shift and unshift; accessor methods: concat, join, slice, indexOf and lastIndexOf; iteration methods: filter, every, forEach, map, some, reduce and reduceRight). D3.js extends this functionality with:
- Functions for finding minimum, maximum, extent, sum, mean, median, and quantile of an array.
- Functions for ordering, shuffling, permuting, merging, and bisecting arrays.
- Functions for nesting arrays.
- Functions for manipulating associative arrays.
- Support for map and set collections.
Geometry
- Computing convex hull of a set of points.
- Computing Voronoi tesselation of a set of points.
- Support for point quadtree data structure.
- Support for basic operations on polygon.
Color
- Support for RGB, HSL, HCL, and L*a*b* color representation.
- Brightening, darkening, and interpolation of colors.
References
- ^ "d3 Releases". Github.com. Retrieved April 25, 2018.
- ^ "For Protovis Users", Mbostock.github.com, retrieved August 18, 2012
- ^ Viau, Christophe (June 26, 2012), "What's behind our Business Infographics Designer? D3.js of course", Datameer's blog, retrieved August 18, 2012
- ^ Myatt, Glenn J.; Johnson, Wayne P. (September 2011), "5.10 Further reading", Making Sense of Data III: A Practical Guide to Designing Interactive Data Visualizations, Hoboken, New Jersey: John Wiley & Sons, p. A–2, ISBN 978-0-470-53649-0, retrieved January 23, 2013
- ^ "Release Notes", D3.js, retrieved August 22, 2012
- ^ https://www.wappalyzer.com/technologies/d3
- ^ Academic example: Savva, Manolis; Kong, Nicholas; Chhajta, Arti; Li, Feifei; Agrawala, Maneesh; Heer, Jeffrey (2011), "ReVision: Automated Classification, Analysisand Redesign of Chart Images", ACM User Interface Software & Technology, retrieved January 23, 2013
- ^ Bostock, Ogievetsky & Heer 2011
- ^ Bostock, Ogievetsky & Heer 2011, chap. 3
- ^ Bostock, Mike (February 5, 2012), Thinking with Joins
- ^ "A Pen by Lopez Hugo". Codepen.io. Retrieved August 1, 2016.
- ^ "Edit fiddle". JSFiddle.net. Retrieved August 1, 2016.
- ^ "Three Little Circles". Mbostock.github.io. Retrieved August 1, 2016.
- ^ d3 (June 30, 2016). "API Reference · d3/d3 Wiki · GitHub". Github.com. Retrieved August 1, 2016.
{{cite web}}
: CS1 maint: numeric names: authors list (link)
Further reading
Background on D3.js itself:
- Bostock, Michael; Ogievetsky, Vadim; Heer, Jeffrey (October 2011), "D3: Data-Driven Documents", IEEE Transactions on Visualization and Computer Graphics, 17 (12), IEEE Press: 2301–2309, doi:10.1109/TVCG.2011.185, PMID 22034350
Using D3.js - beginner level:
- Murray, Scott (March 2013), Interactive Data Visualization for the Web, An Introduction to Designing with D3 (1st ed.), Sebastopol, California: O’Reilly Media, ISBN 978-1-4493-3973-9
- Timms, Simon (September 2013), Social Data Visualization with HTML5 and JavaScript (1st ed.), Birmingham: Packt Publishing, ISBN 978-1-7821-6654-2
Using D3.js - intermediate level:
- Dewar, Mike (June 2012), Steele, Julie; Blanchette, Meghan (eds.), Getting Started with D3, Creating Data-Driven Documents (1st ed.), Sebastopol, California: O’Reilly Media, ISBN 978-1-4493-2879-5
- Qi Zhu, Nick (October 2013), Data Visualization with D3.js Cookbook (1st ed.), Birmingham: Packt Publishing, ISBN 978-1-7821-6216-2
Others
- Newton, Thomas; Villarreal, Oscar (2014), Learning D3.js Mapping, Birmingham: Packt Publishing, p. 126, ISBN 9781783985609
- Navarro Castillo, Pablo (2014), Mastering D3.js, Birmingham: Packt Publishing, p. 352, ISBN 9781783286270
- Teller, Swizec (2013), Data Visualization with d3.js, Birmingham: Packt Publishing, p. 194, ISBN 9781782160007
- Viau, Christophe (2013), Developing a D3.js Edge: Constructing Reusable D3 Components and Charts, Bleeding Edge Press, p. 268, ISBN 9781939902023
- Meeks, Elijah (2014), D3.js in Action, Manning Publications, p. 325, ISBN 9781617292118
- Maclean, Malcolm (2014), D3 Tips and Tricks, Leanpub, p. 580
- King, Ritchie (2014), Visual Storytelling with D3: An Introduction to Data Visualization in JavaScript, Addison-Wesley Data & Analytics Series, p. 288
Videos
- Gopal, Nikhil (October 2014), D3 and CoffeeScript: A Python Programmer's Introduction to Web Visualizations, Sebastopol, California: O’Reilly Media
- King, Ritchie (December 2014), D3 Visualization LiveLessons: An Introduction to Data Visualization in JavaScript, Addison-Wesley Professional
External links
- Official website
- D3.js Gallery
- Blocksplorer, search for blocks by methods used