ebook img

D3 on AngularJS Create Dynamic Visualizations with AngularJS PDF

144 Pages·2014·2.935 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview D3 on AngularJS Create Dynamic Visualizations with AngularJS

D3 on AngularJS Create Dynamic Visualizations with AngularJS Ari Lerner and Victor Powell Thisbookisforsaleathttp://leanpub.com/d3angularjs Thisversionwaspublishedon2014-04-15 ThisisaLeanpubbook.LeanpubempowersauthorsandpublisherswiththeLeanPublishing process.LeanPublishingistheactofpublishinganin-progressebookusinglightweighttoolsand manyiterationstogetreaderfeedback,pivotuntilyouhavetherightbookandbuildtractiononce youdo. ©2013-2014AriLernerandVictorPowell Tweet This Book! PleasehelpAriLernerandVictorPowellbyspreadingthewordaboutthisbookonTwitter! Thesuggestedhashtagforthisbookis#d3angular. Findoutwhatotherpeoplearesayingaboutthebookbyclickingonthislinktosearchforthis hashtagonTwitter: https://twitter.com/search?q=#d3angular Contents Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Abouttheauthors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Aboutthisbook . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Organizationofthisbook . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 Additionalresources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 Conventionsusedinthisbook . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 Developmentenvironment . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 IntroducingD3.Asimpleexample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 Whatisit? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 ‘HelloWorld’D3style . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 SelectionsAndDataBinding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 Selections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 Selectormethods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Databinding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 .enter()method . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 exit() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Generalupdatepattern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 SVGbasics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 ScalableVectorGraphics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 Gettingstarted . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 SVGcoordinates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 SVGandD3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 Arrayhelpers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 Accessingandmanipulatingsimplearrays . . . . . . . . . . . . . . . . . . . . . . . . . . 56 Associativearrayhelpers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 Maps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 Sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 Nests . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 Applyingourknowledge . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 Scales . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 CONTENTS Axes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 Animationandinteraction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 DataParsingandFormatting. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 Whatnext? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 IntrotoAngular . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 AboutAngular . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102 HelloAngular! . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 Directivesforreusablevisualizations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108 Understandingdirectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108 Creatingadirective . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108 Adonutchartdirective . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 Isolatescope . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 Dynamicvisualizations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 Twowaydatabinding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115 Makingvisualizationsdynamicwith$watch . . . . . . . . . . . . . . . . . . . . . . . . . 119 Gettingdataintoandoutofdirectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 TheD3way . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 TheAngularway . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128 Updatingthescopefromwithinadirective . . . . . . . . . . . . . . . . . . . . . . . . . . 130 Bestpracticesforcreatingreusablevisualizations . . . . . . . . . . . . . . . . . . . . . . 132 Accessorfunctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132 Responsivedirectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 134 Services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 136 Builtindirectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137 Usingreplace,template,andtranscludetomodifythebehaviorofourvisualizations . . 137 Introduction About the authors AriLernerisadeveloperwithmorethan20yearsofexperience,andco-founderofFullstack.io.He co-runsng-newsletter,speaksatconferences,andrecentlyreleasedRidingRailswithAngularJS.He alsoteachesin-personclassesatHackReactorandonlinewithairpair. Victor Powell is a freelance data visualization developer. Prior to freelance, Victor built data visualization tools with YinzCam, Inc. used by NFL, NHL, and NBA sports teams. In his free time, Victor enjoys finding ways to explaining unintuitive or complex mathematical concepts visually. VictoralsoguestinstructsatHackReactor. About this book TheD3onAngularJS bookispackedwiththesolutionsyouneedtobeaD3¹andAngularJS²expert. AngularJS is an advanced front-end framework released by the team at Google³. It enables you to build a rich front-end experience, quickly and easily and D3 is an advanced data visualization frameworkreleasedbyMikeBostock. TheD3onAngularJSgivesyouthecutting-edgetoolsyouneedtogetupandrunningonAngularJS and creating impressive web experiences in no time. The goal of this book is not only to give you a deep understanding of how D3 works, but how to integrate it properly into your own AngularJS apps. Withthese toolsyoucan diveintomaking yourown dynamicvisualizations with AngularJSwhile beingconfidentinunderstandingthetechnology. Audience We have written this book for those who have never used AngularJS to build a web application and are curious about how to get started with an awesome JavaScript framework. We assume that you have a working knowledge of HTML and CSS and a familiarity with basic JavaScript (and possibly other JavaScriptframeworks).Wealsoassume that you’veneverwritten in D3before,but areinterestedinlearning. ¹http://d3js.org/ ²http://angularjs.org ³http://google.com Introduction 2 Organization of this book The first half off the book focuses exclusively on the basics of D3 so we’ll start off assuming you have not used the Library before. In the second half of the book, we’ll cover Angular and how it can be used to make reusable data visualization components. We’ll also assume you have not used Angularbutatthesametime,wewon’tgetintotoomanydetailsoftheLibraryandonlycoverthe conceptsthatspecificallyaidincreatingreusableandinteractivedatavisualizations. Additional resources SincethisbookdoesnotcoverAngularJSin-depth,weurgeyoutocheckouttheCompleteBookon AngularJSatng-book.com⁴. We suggest that you take a look at theAngularJS API documentation⁵, as it gives you direct access totherecommendedmethodsofwritingAngularapplications.Italsogivesyouthemostup-to-date documentationavailable. Conventions used in this book Throughout this book, you will see the following typographical conventions that indicate different typesofinformation: In-linecodereferenceswilllooklike:<h1>Hello</h1>. Ablockofcodelookslikeso: 1 var app = angular.module('app', []); 2 3 function FirstController($scope) { 4 $scope.data = "Hello"; 5 } Anycommandatthecommandlinewilllooklike: 1 $ ls -la Any command in the developer console in Chrome (the browser with which we will primarily be developing)willlooklike: ⁴https://www.ng-book.com ⁵http://docs.angularjs.org/api Introduction 3 1 > var obj = {message: "hello"}; Importantwords willbeshowninbold. Finally,tipsandtrickswillbeshownas: Tip:Thisisatip Development environment In order to write any applications using AngularJS or D3, we first need to have a comfortable developmentenvironment.Throughoutthisbook,we’llbespendingmostofourtimeintwoplaces: our text editor and our browser. We recommend you download the Google Chrome browser, as it provides a great environment to develop in with its convenient and built-in developer tools suite. It’salsothebrowserweusedtocreatetheexamples.Intheory,thereshouldbenodifferencesinthe waytheexamplesrunonotherstandardscompliantbrowsersbutwecan’teverbeabsolutelysure. Introducing D3. A simple example Inthischapter,we’llgooverwhatD3isandwhatmakesitsuchapowerfultoolfordatavisualization. We’ll also introduce a simple ‘Hello World’ style example that shows how to get quickly get setup andrunningwithD3. What is it? D3(orData-DrivenDocuments)isalibrarywrittenbyMikeBostock⁶for“manipulatingdocuments basedondata.”ThismeansD3’sprimaryjobistotakedataandproducestructureddocumentssuch as HTML or SVG with respect to data. Unlike most visualization libraries, D3 is not a ready-made collectionofcommongraphsandwidgets.It’scommontouseD3tomakecommongraphs,likebar charts and pie charts, but the real power is in its flexibility and fine grain control over the final result. D3workswellwithotherestablishedwebtechnologieslikeCSSandSVGbecauseitdoesn’tattempt toabstractawaytheDOM,likemanyothergraphinglibraries.ThisalsomeansD3willcontinueto beusefulasbrowsersincorporatenewfeatures. Ifwe’rejustlookingforaparticulargraphtype,say,abarchart,anddon’tcarehowexactlyitends uplooking,D3mightnotbetherightlibraryforthejob.Severalotherready-madelibrariesexistfor creatingsimple,cookie-cuttercharts,suchasHighCharts⁷orChart.js⁸orGoogleChartsAPI⁹.If,on the other hand, we have strong requirements for how our visualization should look and function, D3isagreatchoice. To quickly jump into a real world example of this, take the following interactive visualization producedbyKQED’stheLowdownblog.Itdoesn’tfallintoasingle,chartcategoryandthedifferent chartcomponentsneedtocommunicatewitheachother,updatingdynamically. ⁶http://bost.ocks.org/mike/ ⁷http://www.highcharts.com/ ⁸http://www.chartjs.org/ ⁹https://developers.google.com/chart/ IntroducingD3. Asimpleexample 5 Liveversionoftheaboveinteractivevisualization¹⁰ ItwascreatedusingacombinationofAngularandD3.(sourcecodeisavailablehere¹¹). To illustrate this point, we’ll also walk though a little thought experiment. Imagine we’re working withaready-madevisualizationlibrary.TypicalvisualizationlibrariesmighthaveaBarChartclass tocreateanewbarchartwhichworksfineuntilwewanttodosomethingthelibrarydidn’tallowto beconfigured.Forexample,saywewantedtochangethebackgroundcolorofthelegendinourbar chart.Wecouldtaketheircodeandtryandmodifyittoaddourneededfeature,butthatcanquickly ¹⁰http://blogs.kqed.org/lowdown/2014/03/18/into-the-drought-californias-shrinking-reservoirs/ ¹¹https://github.com/vicapow/water-supply

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.