SuperHi FM

ADVANCEDCOURSE

Data Visualization + D3.js

Learn how to create interactive, engaging experiences using HTML, CSS, SVG and Javascript.

Rik Lomas

Taught by

Rik Lomas

Our Data Visualization course focuses on the practical aspects of working with data. In our 6-week long course, we’ll cover the basics of storytelling and working with data in a creative, fun way. You’ll learn how to create interactive, engaging experiences using HTML, CSS, SVG and Javascript.

This course, aimed at beginners, will teach you how to work with data and choose the right visuals to represent it effectively. We’ll introduce the basics of the powerful D3.js library used to animate and add interactions to your charts and graphs. You’ll also learn how to pull data from the web using Ajax.

You don’t need to be a designer or experienced coder to join the course but a little knowledge of HTML and CSS will help.

What you’ll learn

  • The different types of data visualizations and how to use them effectively
  • How to work with and understand data sets and turn them into engaging experiences
  • How to use HTML, CSS, SVG to design charts and graphs
  • How to use Javascript to add animations, transitions and interactions to your experiences
  • An introduction to the fundamentals of the powerful Javascript library D3.js
  • Using Ajax to pull data from the web into your visualizations

Requirements

A computer (Windows, Mac or Linux) with the latest version of Chrome installed and a broadband internet connection. That’s it!

Target Audience

Anyone who is looking for ways to work with data-driven design or work closer with designers to implement beautiful visualizations of data.

We would recommend a little knowledge of HTML, CSS and Javascript before starting this course. Reading our Learn To Code Now book or taking either Foundation HTML, CSS + JS will be sufficient.

Step Count – HTML, CSS + SVG

In the first part of the course, we'll lay out our Step Count project using HTML and CSS, plus introduce SVG tags to draw our data visualizations.

Go to chapter
Step Count – automating with Javascript

With Javascript, we can save a lot of time manually writing out HTML tags by writing scripts to automate drawing visuals.

Go to chapter
Step Count – Introducing D3

Using the right tool for the right job! Using D3, a Javascript library made for simplifying data visualizations, we'll save time and energy making our designs.

Go to chapter
Step Count – Extending D3

D3 comes with a lot of tools as part of the library. In this session, we'll add transitions with delays and easing, talk about the importance of grouping, and use D3's array functions to save us time!

Go to chapter
Heat map

In Heat Map, we discuss how to take more complex data and turn it into a vibrant visualization featuring hover effects, a temperature scale changer and our first look at line graphs.

Go to chapter
Discover the World

In this lesson, we use a scattergraph-style visualization to compare data in two dimensions. We also add in transitions on updated data, add in axes and talk about responsive designs.

Go to chapter
The Top – Part 1

After a debate within the SuperHi team, we test to see if movies that are popular with fans correlate with popularity with the critics by using scores from fan-scored IMDb and critic-scored Metacritic in week 4's project, The Top.

Go to chapter
The Top – Part 2

In the second part of The Top, we add in line and area shapes to make our visualization clearer, and add in labels for our scores. We also discuss responsive design and media queries to make our designs suitable for any device.

Go to chapter
Kiddo Kiddo

In this brand new project, we discuss how to work with different scales, incomplete lines and how to change our data visualization based on our users' search results.

Go to chapter
Boundless

With D3, we can quickly add in more complex shapes such as arcs and pies. In the Boundless project, we add a pie chart that updates every half-second with an interval loop.

Go to chapter
StockFinder

Previously, all the data used has been static – we only see changes to our designs when we change our data – but in this project, we add in live data that can change based on real-life information such as Apple's stock price.

Go to chapter
Population Densities of the World

In the last part of the course, we talk about how to add in geographic maps and talk about how to apply data to countries within our map.

Go to chapter

Get access to Data Visualization + D3.js

  • Practical, go-at-your-own pace learning, with help from our industry experts and experienced teachers
  • Projects and code that you can alter and include in your own sites and portfolio
  • Resources to get you started and going post-course

Your instructor

Rik Lomas

Rik Lomas

Founder + CEO

Rik (he/him) is a Mancunian coder, teacher and CEO of SuperHi. He was the co-founder of Steer (a code school in London) and has taught several thousand people to code. He is a bit too old to be posting memes on our social media and recently featured as a Sour Patch Kid in the Macy's Thanksgiving Parade.

With support from...
Kristen Altomare-Ciallella

Kristen Altomare-Ciallella

Product Designer

Course structure

  1. Welcome to the Data Visualization + D3 course

    Lesson 01

    Welcome to the Data Visualization + D3 course

  2. Introduction to the Step Counter project

    Lesson 02

    Introduction to the Step Counter project

  3. What is the SuperHi Editor?

    Lesson 03

    What is the SuperHi Editor?

  4. Adding basic HTML structure for our project

    Lesson 04

    Adding basic HTML structure for our project

  5. Adding navigation bar content

    Lesson 05

    Adding navigation bar content

  6. Introducing our CSS

    Lesson 06

    Introducing our CSS

  7. Adding webfont typography

    Lesson 07

    Adding webfont typography

  8. Adding extra type styles

    Lesson 08

    Adding extra type styles

  9. How to add CSS rules

    Lesson 09

    How to add CSS rules

  10. Adding spacing using margins

    Lesson 10

    Adding spacing using margins

  11. Giving our project layout with CSS Grid

    Lesson 11

    Giving our project layout with CSS Grid

  12. Filling in our main content area

    Lesson 12

    Filling in our main content area

  13. Inside an SVG

    Lesson 13

    Inside an SVG

  14. Adding a rect tag

    Lesson 14

    Adding a rect tag

  15. Drawing circles

    Lesson 15

    Drawing circles

  1. Welcome to automating our HTML

    Lesson 01

    Welcome to automating our HTML

  2. How to add a Javascript file

    Lesson 02

    How to add a Javascript file

  3. Picking tags and changing HTML

    Lesson 03

    Picking tags and changing HTML

  4. Updating the style of selected tags

    Lesson 04

    Updating the style of selected tags

  5. Using forEach to loop through tags

    Lesson 05

    Using forEach to loop through tags

  6. Variation: adding randomness

    Lesson 06

    Variation: adding randomness

  7. forEach with an index

    Lesson 07

    forEach with an index

  8. Changing our rect tags using forEach

    Lesson 08

    Changing our rect tags using forEach

  9. Using index to change widths

    Lesson 09

    Using index to change widths

  10. Adding in a data array

    Lesson 10

    Adding in a data array

  11. Automating addition of rect tags

    Lesson 11

    Automating addition of rect tags

  12. Positioning our rect tags

    Lesson 12

    Positioning our rect tags

  13. Homework

    Lesson 13

    Homework

  14. Homework solution

    Lesson 14

    Homework solution

  1. Welcome to Week 2!

    Lesson 01

    Welcome to Week 2!

  2. What is D3 and why do we use it?

    Lesson 02

    What is D3 and why do we use it?

  3. How to add D3 to a project

    Lesson 03

    How to add D3 to a project

  4. Using select and selectAll with D3

    Lesson 04

    Using select and selectAll with D3

  5. Adding data to D3 and using attr

    Lesson 05

    Adding data to D3 and using attr

  6. Automating attribute changes

    Lesson 06

    Automating attribute changes

  7. Adding in rect tags automatically with D3

    Lesson 07

    Adding in rect tags automatically with D3

  8. Adding in real data

    Lesson 08

    Adding in real data

  9. Introducing scales

    Lesson 09

    Introducing scales

  10. Adding text tags to our data visualizations

    Lesson 10

    Adding text tags to our data visualizations

  11. Adding classes and circle tags

    Lesson 11

    Adding classes and circle tags

  12. Thinking about grids

    Lesson 12

    Thinking about grids

  13. The modulo (%) and Math.floor to make a grid

    Lesson 13

    The modulo (%) and Math.floor to make a grid

  14. Scaling our circle's radius

    Lesson 14

    Scaling our circle's radius

  15. Homework

    Lesson 15

    Homework

  16. Homework solution

    Lesson 16

    Homework solution

  1. Welcome to the final part of Step Count

    Lesson 01

    Welcome to the final part of Step Count

  2. Adding in a transition

    Lesson 02

    Adding in a transition

  3. Adding delay and easing to transitions

    Lesson 03

    Adding delay and easing to transitions

  4. Adding transitions to our bar chart

    Lesson 04

    Adding transitions to our bar chart

  5. Why we group tags in our visualizations

    Lesson 05

    Why we group tags in our visualizations

  6. Adding g tags to our bar chart

    Lesson 06

    Adding g tags to our bar chart

  7. Adding our second text tags

    Lesson 07

    Adding our second text tags

  8. Adding hover states using CSS

    Lesson 08

    Adding hover states using CSS

  9. Adding both classes and states in CSS

    Lesson 09

    Adding both classes and states in CSS

  10. Hovering within a group

    Lesson 10

    Hovering within a group

  11. Adding a group for our circles

    Lesson 11

    Adding a group for our circles

  12. Adding in goal rings using stroke

    Lesson 12

    Adding in goal rings using stroke

  13. Adding text to our Last 28 Days section

    Lesson 13

    Adding text to our Last 28 Days section

  14. Altering HTML content

    Lesson 14

    Altering HTML content

  15. D3's array functions

    Lesson 15

    D3's array functions

  16. Using D3 Format

    Lesson 16

    Using D3 Format

  17. Homework

    Lesson 17

    Homework

  18. Homework solution

    Lesson 18

    Homework solution

  1. Welcome to Heat Map

    Lesson 01

    Welcome to Heat Map

  2. Creating our HTML content

    Lesson 02

    Creating our HTML content

  3. Adding our overall page styling

    Lesson 03

    Adding our overall page styling

  4. Adding our header layout

    Lesson 04

    Adding our header layout

  5. Storing data in arrays and objects

    Lesson 05

    Storing data in arrays and objects

  6. How our data file looks

    Lesson 06

    How our data file looks

  7. Data collection using the Javascript Developer tools

    Lesson 07

    Data collection using the Javascript Developer tools

  8. Adding our script tags

    Lesson 08

    Adding our script tags

  9. Reflecting our data in design

    Lesson 09

    Reflecting our data in design

  10. Setting up our group tags

    Lesson 10

    Setting up our group tags

  11. Adding our cities to the data visualization

    Lesson 11

    Adding our cities to the data visualization

  12. Adding our country text tag

    Lesson 12

    Adding our country text tag

  13. Adding data groups within data points

    Lesson 13

    Adding data groups within data points

  14. Color scales

    Lesson 14

    Color scales

  15. Adding labels to our heat map

    Lesson 15

    Adding labels to our heat map

  16. Adding box scale

    Lesson 16

    Adding box scale

  17. What is a path tag

    Lesson 17

    What is a path tag

  18. D3's line generators

    Lesson 18

    D3's line generators

  19. Changing temperature units with a select tag

    Lesson 19

    Changing temperature units with a select tag

  20. Homework

    Lesson 20

    Homework

  21. Homework solution

    Lesson 21

    Homework solution

  1. Welcome to Discover The World

    Lesson 01

    Welcome to Discover The World

  2. Setting up our HTML

    Lesson 02

    Setting up our HTML

  3. Adding our styling

    Lesson 03

    Adding our styling

  4. Adding our own Javascript functions

    Lesson 04

    Adding our own Javascript functions

  5. Adding events to both page load and select tag changes

    Lesson 05

    Adding events to both page load and select tag changes

  6. Setting up our Javascript

    Lesson 06

    Setting up our Javascript

  7. How we got our data source

    Lesson 07

    How we got our data source

  8. Adding groups per city

    Lesson 08

    Adding groups per city

  9. Adding scales to our data

    Lesson 09

    Adding scales to our data

  10. Changing our data depending on which value

    Lesson 10

    Changing our data depending on which value

  11. Hooking our select tags up

    Lesson 11

    Hooking our select tags up

  12. Adding movement to select changes

    Lesson 12

    Adding movement to select changes

  13. Changing our circle radius data

    Lesson 13

    Changing our circle radius data

  14. Adding axes

    Lesson 14

    Adding axes

  15. Styling our axes

    Lesson 15

    Styling our axes

  16. Adding axis labels

    Lesson 16

    Adding axis labels

  17. Adding a city label

    Lesson 17

    Adding a city label

  18. Raising in D3

    Lesson 18

    Raising in D3

  19. Responsive design with SVG viewBox

    Lesson 19

    Responsive design with SVG viewBox

  20. Homework

    Lesson 20

    Homework

  21. Homework solution

    Lesson 21

    Homework solution

  1. Welcome to The Top

    Lesson 01

    Welcome to The Top

  2. Why this data and why visualize it in this way

    Lesson 02

    Why this data and why visualize it in this way

  3. Setting up our HTML

    Lesson 03

    Setting up our HTML

  4. CSS page styles

    Lesson 04

    CSS page styles

  5. Styling our header

    Lesson 05

    Styling our header

  6. Making a sticky header

    Lesson 06

    Making a sticky header

  7. Creating our groups from the data set

    Lesson 07

    Creating our groups from the data set

  8. Fixing our text and header

    Lesson 08

    Fixing our text and header

  9. Adding circle tags to each group

    Lesson 09

    Adding circle tags to each group

  10. Sorting our data by a key

    Lesson 10

    Sorting our data by a key

  11. Sorting data by the select tag + homework

    Lesson 11

    Sorting data by the select tag + homework

  12. Homework solution

    Lesson 12

    Homework solution

  13. Data visualization accessibility

    Lesson 13

    Data visualization accessibility

  1. Welcome to part 2 of The Top

    Lesson 01

    Welcome to part 2 of The Top

  2. Adding a background hover to each group

    Lesson 02

    Adding a background hover to each group

  3. Adding our line shapes

    Lesson 03

    Adding our line shapes

  4. Updating our lines on select box change

    Lesson 04

    Updating our lines on select box change

  5. Adding curves to lines

    Lesson 05

    Adding curves to lines

  6. D3's area shape

    Lesson 06

    D3's area shape

  7. forEach vs map

    Lesson 07

    forEach vs map

  8. Making a difference

    Lesson 08

    Making a difference

  9. Adding our text scores

    Lesson 09

    Adding our text scores

  10. Responsive design, part 1

    Lesson 10

    Responsive design, part 1

  11. Responsive design, part 2

    Lesson 11

    Responsive design, part 2

  12. Homework

    Lesson 12

    Homework

  13. Spin class

    Homework 01

    Spin class

  1. Welcome to Kiddo Kiddo

    Lesson 01

    Welcome to Kiddo Kiddo

  2. Our data source

    Lesson 02

    Our data source

  3. Adding our HTML content

    Lesson 03

    Adding our HTML content

  4. Styling our header and form

    Lesson 04

    Styling our header and form

  5. Styling our key

    Lesson 05

    Styling our key

  6. Setting up our form in Javascript

    Lesson 06

    Setting up our form in Javascript

  7. Filtering the data set

    Lesson 07

    Filtering the data set

  8. Adding our paths

    Lesson 08

    Adding our paths

  9. Defining paths

    Lesson 09

    Defining paths

  10. Exit data

    Lesson 10

    Exit data

  11. Adding axes

    Lesson 11

    Adding axes

  12. Different types of scales

    Lesson 12

    Different types of scales

  13. Transitioning in and out

    Lesson 13

    Transitioning in and out

  14. Gendering colors

    Lesson 14

    Gendering colors

  15. Homework

    Lesson 15

    Homework

  1. Welcome to Boundless

    Lesson 01

    Welcome to Boundless

  2. Setting up our project

    Lesson 02

    Setting up our project

  3. Setting up our updateGraph script

    Lesson 03

    Setting up our updateGraph script

  4. Making a quick bar graph

    Lesson 04

    Making a quick bar graph

  5. Making a pie generator + arc generator

    Lesson 05

    Making a pie generator + arc generator

  6. Pie and arc options

    Lesson 06

    Pie and arc options

  7. Update the pie chart on next button

    Lesson 07

    Update the pie chart on next button

  8. Autoplaying the visualization

    Lesson 08

    Autoplaying the visualization

  9. Time formatting

    Lesson 09

    Time formatting

  10. Stopping the loop when we have no data

    Lesson 10

    Stopping the loop when we have no data

  11. Arc tweening

    Lesson 11

    Arc tweening

  12. Homework

    Lesson 12

    Homework

  1. Welcome to StockFinder

    Lesson 01

    Welcome to StockFinder

  2. Setting up our project

    Lesson 02

    Setting up our project

  3. Pulling our data in using d3.json()

    Lesson 03

    Pulling our data in using d3.json()

  4. Processing our data

    Lesson 04

    Processing our data

  5. Finding the min and max data points

    Lesson 05

    Finding the min and max data points

  6. Adding our scales

    Lesson 06

    Adding our scales

  7. Making our line generator and graph

    Lesson 07

    Making our line generator and graph

  8. Adding an area generator

    Lesson 08

    Adding an area generator

  9. Adding in live data

    Lesson 09

    Adding in live data

  10. Adding in our hover tooltip

    Lesson 10

    Adding in our hover tooltip

  11. Moving our tooltip across the page

    Lesson 11

    Moving our tooltip across the page

  12. Hiding our tooltip on mouseout

    Lesson 12

    Hiding our tooltip on mouseout

  13. Finding the date on hover

    Lesson 13

    Finding the date on hover

  14. Bisecting our data

    Lesson 14

    Bisecting our data

  15. Fixing our tooltip to the line

    Lesson 15

    Fixing our tooltip to the line

  16. Extra resources

    Lesson 16

    Extra resources

  1. Welcome to Population Densities of the World

    Lesson 01

    Welcome to Population Densities of the World

  2. Loading in our dataset

    Lesson 02

    Loading in our dataset

  3. Adding in map projections

    Lesson 03

    Adding in map projections

  4. Drawing country by country

    Lesson 04

    Drawing country by country

  5. Highlighting a country

    Lesson 05

    Highlighting a country

  6. Mapping our data to our countries

    Lesson 06

    Mapping our data to our countries

  7. Adding a color scale

    Lesson 07

    Adding a color scale

  8. Filtering based on scroll

    Lesson 08

    Filtering based on scroll

  9. Adding scales to our scroll position

    Lesson 09

    Adding scales to our scroll position

  10. Homework

    Lesson 10

    Homework

  11. Thank you for being part of our course!

    Lesson 11

    Thank you for being part of our course!

SuperHi students work at the best

Our students are based all over the world and work at creative companies large and small. Why not check out some of their work?

View student work

Feeling stuck?

Don’t worry, we are here to help you with:

  • Speedy help from one of our team members
  • Detailed, relevant solutions
  • Direct access to peer support through Discord!

Remember, there’s no such thing as a silly question, so don’t hesitate to reach out, we love hearing from you!