Codementor Events

D3.js - join()

Published Mar 12, 2020
D3.js - join()

Just as you thought you'd got to grips with the .merge() function, it changes again in D3.js version 5.

There is no crisis here, .merge() works perfectly in version 5 as well but it's always good to embrace change!

.join() is designed as a

more convenient and memorable API for joining data without sacrificing anything

There is a brilliant explanation of how it works when you're appending data to a single element by Mike Bostock - no need to expand there.

This article is a quick extension to show how you can append data to a group which can then be applied to multiple elements.

In this article I explain the process with the .merge() functionality.

The good news is that using .join() instead is less lines of code as well as all the extra potential to highlight data elements which are current and new.

So the update_group function in the original demo:

       //join
       var my_group = svg.selectAll('.chart_group')
                         .data(data, d => d.id);
       //exit and remove
       my_group.exit().remove();
       //enter new groups
       var enter = my_group.enter()
                           .append("g")
                           .attr("class","chart_group");

       //append elements to new group
       enter.append("rect").attr("class","group_rect");
       enter.append("text").attr("class","group_text");
       enter.append("image").attr("class","group_image");

       //merge 
       my_group = my_group.merge(enter);

becomes this in the new demo

//join
 var my_group = svg.selectAll('.chart_group')
                   .data(data, d => d.id)
                   .join(function(group){
                    var enter = group.append("g").attr("class","chart_group");
                            enter.append("rect").attr("class","group_rect");
                            enter.append("text").attr("class","group_text");
                            enter.append("image").attr("class","group_image");
                            return enter;
                    });

What could be easier! Thanks again to the wonder of Mr Bostock.

Discover and read more posts from Bryony Miles
get started
post comments3Replies
Kyle Geib
3 years ago

Thank you for this example. I’m a D3 newbie and I was stuck wondering if I couldn’t use .join() to update SVG groups after many failed attempts. Reading your example made me believe what I was attempting was possible. I then dug into the problem and read Bostock’s demo of .join() and discovered the power of defining custom enter/update/exit functions and was able to make it work.

If anyone wants to dig deep if you’re having my same exact problem, here was my solution:
https://github.com/TiE23/sab-d3/blob/694527319cf1d2e94001043125e29204197c1412/08-common-charts/radar/chart.js#L194-L270

Víctor Adrián de la Cruz Serrano
5 years ago

I think you should be using let and const and not var in 2020. :)

Bryony Miles
5 years ago

You are of course right Victor. Force of habit. I will update this when I get a moment.