DEV Community

Cover image for D3.js tutorial: Build your first bar chart
Erin Schaffer for Educative

Posted on • Originally published at educative.io

D3.js tutorial: Build your first bar chart

D3.js is a JavaScript library that enables you to create dynamic data visualizations in web browsers. It specializes in visualizing large data sets in an understandable and interactive way. The D3.js library stands out as one of the best data visualization tools for front-end developers because of its core features, such as DOM manipulation, dynamic properties, and animations.

Today, we’re going to show you how to build your first bar chart using D3.js. Let’s get started!

We’ll cover:

Project overview

Today, we’re going to build a bar chart using D3.js. This is a great project because it allows you to practice your D3.js data visualization skills in a practical way.

Bar charts are a useful and effective way to compare data between different groups. They improve readability, allowing you to easily identify patterns or trends in your data.

D3.js is great for data visualization for many reasons, such as:

  • Visuals: works with HTML, CSS, and SVG so no new tools are required
  • Animations: allows you to animate and modify page elements
  • Supported in all major browsers: works on the web making visuals easy to share and publish
  • Flexible: works well with existing web technologies and can manipulate any part of the DOM
  • Scalable: works well with large sets of data

Initial setup

There are three things we need to do before creating our bar chart:

  1. Set up the document’s head and body
  2. Set up the CSS
  3. Load the d3.js library

They can all be done with the following code:

<!DOCTYPE html>
<meta charset="utf-8">
<style> /* set the CSS */

.bar { fill: steelblue; }

</style>
<body>

<!-- load the d3.js library -->     
<script src="https://d3js.org/d3.v6.min.js"></script>
<script>
Enter fullscreen mode Exit fullscreen mode

In the <style> section of the code, we set the styling for the color of the bars. Placing the style at the beginning of the code is optional, but it is convenient to do early.

Create your dataset

We need data before we can begin working on our bar chart. For this tutorial, we’re going to work with some sample data from a fictional external CSV file named amounts.csv.

The file consists of a column of names and amounts:

name,amounts
Foo, 33
Rishab, 12
Alexis, 41
Tom, 16
Courtney, 59
Christina, 38
Jack, 21
Mickey, 25
Paul, 30
Enter fullscreen mode Exit fullscreen mode

We will use this data to make a vertical bar chart that stores the values of the amounts.

Set dimensions and margins

Let's set the size of the area that we’re going to use for the chart and the margins.

// Set graph margins and dimensions
var margin = {top: 20, right: 20, bottom: 30, left: 40},
    width = 960 - margin.left - margin.right,
    height = 500 - margin.top - margin.bottom;
Enter fullscreen mode Exit fullscreen mode

Now, we'll determine the ranges of the x and y domains:

// Set ranges
var x = d3.scaleBand()
          .range([0, width])
          .padding(0.1);
var y = d3.scaleLinear()
          .range([height, 0]);
Enter fullscreen mode Exit fullscreen mode

Append SVG element

The following code selects the body on the webpage and appends an SVG object to it. The size of the SVG object is determined by the width, height, and margin we set up:

var svg = d3.select("body").append("svg")
    .attr("width", width + margin.left + margin.right)
    .attr("height", height + margin.top + margin.bottom)
  .append("g")
    .attr("transform", 
          "translate(" + margin.left + "," + margin.top + ")")
Enter fullscreen mode Exit fullscreen mode

Gather and format data

It’s time to load our data into the body of our script. We will load our CSV file and then loop through it to make sure all data is recognized properly:

// Get data
d3.csv("amounts.csv").then(function(data) {

  // Format
  data.forEach(function(d) {
    d.amounts = +d.amounts;
  });
Enter fullscreen mode Exit fullscreen mode

Scale domains

Before we add our bars, let’s work through our x and y data to make sure it’s scaled to our set domains:

// Scale the range of the data in the domains
  x.domain(data.map(function(d) { return d.name; }));
  y.domain([0, d3.max(data, function(d) { return d.amounts; })]);
Enter fullscreen mode Exit fullscreen mode

Add bars

It’s time to add the bars! The code we write will create the bars and associate each of them with a data set.

 // Append rectangles for bar chart
  svg.selectAll(".bar")
      .data(data)
    .enter().append("rect")
      .attr("class", "bar")
      .attr("x", function(d) { return x(d.name); })
      .attr("width", x.bandwidth())
      .attr("y", function(d) { return y(d.amounts); })
      .attr("height", function(d) { return height - y(d.amounts); });
Enter fullscreen mode Exit fullscreen mode

The last thing we need to do is append our axes, and then we can check out the finished result.

 // Add x axis
  svg.append("g")
      .attr("transform", "translate(0," + height + ")")
      .call(d3.axisBottom(x));

  // Add y axis
  svg.append("g")
      .call(d3.axisLeft(y));
Enter fullscreen mode Exit fullscreen mode

This is what our code should look like in its entirety:

<!DOCTYPE html>
<meta charset="utf-8">
<style> /* set the CSS */

.bar { fill: steelblue; }

</style>
<body>

<!-- load the d3.js library -->     
<script src="https://d3js.org/d3.v6.min.js"></script>
<script>

// Set graph margins and dimensions
var margin = {top: 20, right: 20, bottom: 30, left: 40},
    width = 960 - margin.left - margin.right,
    height = 500 - margin.top - margin.bottom;

// Set ranges
var x = d3.scaleBand()
          .range([0, width])
          .padding(0.1);
var y = d3.scaleLinear()
          .range([height, 0]);
var svg = d3.select("body").append("svg")
    .attr("width", width + margin.left + margin.right)
    .attr("height", height + margin.top + margin.bottom)
  .append("g")
    .attr("transform", 
          "translate(" + margin.left + "," + margin.top + ")");

// Get data
d3.csv("amounts.csv").then(function(data) {

  // Format data
  data.forEach(function(d) {
    d.amounts = +d.amounts;
  });

  // Scale the range of the data in the domains
  x.domain(data.map(function(d) { return d.name; }));
  y.domain([0, d3.max(data, function(d) { return d.amounts; })]);

  // Append rectangles for bar chart
  svg.selectAll(".bar")
      .data(data)
    .enter().append("rect")
      .attr("class", "bar")
      .attr("x", function(d) { return x(d.name); })
      .attr("width", x.bandwidth())
      .attr("y", function(d) { return y(d.amounts); })
      .attr("height", function(d) { return height - y(d.amounts); });

  // Add x axis
  svg.append("g")
      .attr("transform", "translate(0," + height + ")")
      .call(d3.axisBottom(x));

  // Add y axis
  svg.append("g")
      .call(d3.axisLeft(y));

});

</script>
</body>
Enter fullscreen mode Exit fullscreen mode

This is our finished bar chart:

Alt Text

Next steps

Congrats on taking your first steps with D3.js data visualization! Bar charts are a great way to visualize large data sets in an understandable and visually appealing way. There’s still a lot to learn about the D3.js library such as:

  • Tree diagrams
  • Sankey diagrams
  • Mapping
  • And much more

To learn about these concepts and learn more about bar graphs in D3.js, check out Educative’s course D3 Tips and Tricks: Interactive Data Visualization. In this course, you’ll explore D3.js, starting with simple line graphs and moving into more advanced concepts such as histograms and drawing elements. By the end, you’ll be able to create awesome data visualizations with D3.

Happy learning!

Continue learning about JavaScript

Top comments (0)