Tutoriel d3

Table des matières

  1. d3, qu'est ce que c'est? Et pourquoi l'adopter?
  2. DOM et d3
  3. Fonctions anonymes
  4. Représentations graphiques
  5. Histogramme
  6. Echelles
  7. Graphique linéaire
  8. Diagramme circulaire
  9. Regroupement des données
  10. Conclusion
  11. Function d3

d3, qu'est ce que c'est? Et pourquoi l'adopter?

d3 est une librairie JS utilisée pour la représentation des données. C'est une librairie qui peut prendre en charge une grande quantité de données et donner naissance à des graphiques dynamiques et interactifs. De plus d3 utilise le HTML, le SVG et le CSS pour toutes ses créations, ce qui la rend compatible avec tous les navigateurs. Les premières impressions sur d3 sont souvent trompeuses, car au premier regard cette librairie semble complexe et difficile à comprendre, c'est un effet causé par la possibilité personnaliser de chaque détails. Pout arriver à cette liberté d'expression, d3 est munie d'une multitude d'outils qu'il faut apprendre à connaître et à maîtriser. Celà peut donner le vertige quand on voit leur nombre, mais au final on apprend vite à jongler avec tous les outils basiques pour en construire d'autres de plus en plus complexes. Dans ce tutoriel, nous allons apprendre à marcher avec d3 et ensuite nous envoler, car d3 nous permet de laisser libre cours à toute notre imagination

DOM et d3

Rien de plus facile que de manipuler le DOM avec d3. Exemple avec l'ajout d'un paragraphe dans le body.

d3
    .select("body")
    .append("p")

Ajoutons du texte dans la balise créee.

    .text("Je viens de crée mon premier paragraphe en d3.")

Ajoutons maintenant une classe.

    .attr("class", "begin")

Nous pouvons utiliser cette classe pour styliser le paragraphe avec du CSS ou nous pouvons le faire directement avec le d3.

    .style("color", "green")
    .style("font-size", "20px");

Lien CodePen.

Fonctions anonymes

La librairie d3 utilise souvent des fonctions anonymes pour des tâches bien différentes, comme pour définir des coordonnées, une hauteur, ... Il existe principalement deux types de fonctions anonymes :

  • function(d)
  • function(d,i)

Nous allons utiliser la seconde car elle nous fournit plus d'informations que la première. Pour voir son fonctionnement il nous faut des données.

let data_set = [5,10,15]

Comme dans le premier exemple générons du DOM pour mieux comprendre comment ça fonctionne.

d3
    .select("body")
    .selectAll("p")
    .data(data_set)
    .enter()
    .append("p")
    .text(function(d,i){
        return("La valeur de d est " + d + " et l'indice de d est " + i + ".");
    })

Nous pouvons utiliser les fonctions anonymes pour définir des attributs ou des propriétés.

    .style("color",function(d){
        if(d < 15){
            return("red");
        }else{
            return("black");
        }
    });

Lien CodePen.

Représentations graphiques

Puisque nous commençons à mieux comprendre comment fonctionne d3, nous allons commencer à l'utiliser pour sa fonction première : les représentations graphiques. Nous allons voir une partie de ce que nous pouvons faire avec d3.

DOM

Nous pouvons utiliser d3 pour créer un histogramme directement dans le DOM, très déconseillé mais nous pouvons le faire. Pour réaliser cet histogramme nous allons créer des div dans le DOM.

d3
    .select("body")
    .selectAll("div")
    .data(dataset)
    .enter()
    .append("div")
    .attr("class","rect")

Puisque nous avons ajouté une classe à nos div nous pouvons utiliser du CSS ou d3 pour leur donner les autres propriétés tel que la hauteur, la largeur, la couleur, ... En d3 :

    .style("width", "25px")
    .style("height", function(d){
    return(d + "px");
    })
    .style("background-color","black")
    .style("display","inline-block")
    .style("margin","5px");

En CSS :

.rect{
    width : 25px;
    height : 75px;
    background-color : black;
    display : inline-block;
    margin : 5px
}

En conclusion, tout peut-être défini soit en CSS soit en d3. Cependant, si on définit la mếme propriété en CSS et en d3, le second va écraser les valeurs du premier, de ce fait nous pouvons définir height dans le CSS et en d3, seule la valeur de d3 sera prise en compte.
Lien CodePen, seulement d3.
Lien CodePen, d3 et CSS.

SVG

Comme nous l'avons expliqué précedemment, faire des représentations graphiques directement dans le DOM est trés déconseillé. Grâce au d3 nous pouvons exploiter toute la puissance du format svg pour nos représentations graphiques. A partir de maintenant nous pouvons mieux définir notre terrain de jeu et ne plus polluer le DOM avec une multitude de div. Pour définir la taille du svg nous allons le plus souvent utiliser des variables car elles nous seront utiles très souvent.

let width = 1000,
    height = 500;
let svg = d3
    .select("body")
    .append("svg")
    .style("width", width)
    .style("height", height);

Lien CodePen.

Canvas et d3

Puisque nous travaillons dans un svg nous allons retrouver beaucoup de similitudes avec le Canvas. Comme par exemple le dessin des cercles. En Canvas :

ctx.arc(x, y, r, begin_angle, end_angle, sens)

Nous avons besoin des coordonnées du centre du cercle (x,y), de la taille du rayon (r), d'un angle de départ et de fin ainsi qu'indiquer dans quel sens nous voulons dessiner le cercle (horlogé ou anti-horlogé). Avec d3 nous allons utiliser les mêmes paramètres pour dessiner des cercles.

let cercle = svg
    .selectAll("circle")
    .data(data_set)
    .enter()
    .append("circle");
cercle
    .style("cx", function(d,i){
        return(i * 100 + 25);
    })
    .style("cy", height/2)
    .style("r", function(d){
        return(d);
    });

Pour les coordonnées du centre nous avons cx qui est défini en fonction de l'index de la donnée, nous l'avons multiplié par 100 pour espacer les cercles les uns des autres et nous avons ajouté 25 pour effectuer une translation vers la droite. Pour cy nous avons juste choisi le milieu du svg. Le rayon est défini par nos données.
Lien CodePen.

Histogramme

Nous allons voir comment réaliser un simple histogramme avec nos données. Pour définir les bâtonnets nous avons besoin de définir les propriétés suivantes :

  • height, la hauteur du bâtonnet, le seul souci que nous avons c'est que les bâtonnets se dessinent du haut vers le bas, nous allons régler les soucis plus bas
  • width, la largeur du bâtonnet, nous pouvons la définir en pixels ou bien en fonction de la largeur du svg
    .style("width", width / data_set.lenght [- bar_padding])
    rappel : les arguments entre [] sont optionels
  • coordonnée x, nous allons souvent utiliser l'index de la donnée
    //les bâtonnets les uns après les autres [avec un margin]
    .style("x", function(d,i){
        return(i * (bar_width [+ bar_margin]));
    })
    //les bâtonnets équidistants sur tout le svg
    .style("x", function(d, i){
        return(i * (width / data_set.lenght));
    })
  • coordonnée y, nous allons résoudre le souci des bâtonnets du haut vers le bas nous allons décaler vers le bas le bâtonnet de toute la hauteur du svg et ensuite soustraire la hauteur que nous donnent nos données
    .style("y", function(d){
        return(height - d);
    })
  • maintenant que notre histogramme est bien crée nous pouvons styliser les bâtonnets comme nous le voulons, en d3 ou en CSS. Exemple:
let bar = svg
    .selectAll("rect")
    .data(data_set)
    .enter()
    .append("rect")
    .style("x", function(d,i){
        return(i * (width / data_set.length) );
    })
    .style("y", function(d){
        return(height - d);
    })
    .style("width", width / data_set.length - 1)
    .style("height", function(d){
        return(d);
    })
    .style("fill","red");

Lien CodePen.

Interactivité

Maintenant que nous avons notre histogramme crée nous allons rajouter un peu d'intercativité dans le graphique afin de mieux observer les données. Par exemple, nous allons mettre en avant le bâtonnet que nous allons survoler avec la souris. En d3, pour garder un seul bâtonnet opaque, il faut rendre tous les bâtonnets transparents et ensuite changer l'opacité de celui survolé.

    .on("mouseover", function(){
        d3
            .selectAll("rect")
            .style("opacity", 0.3);
        d3
            .select(this)
            .style("opacity", 1);
    })

Sans oublier le cas où le graphique n'est pas survolé par la souris.

    .on("mouseout",function(){
        d3
            .selectAll("rect")
            .style("opacity", 1);

    })

Il suffit de rajouter l'interactivité dans la déclaration des bâtonnets (bar) pour que celà fonctionnne.
Lien CodePen.

Label

Parfois il est utile d'afficher la valeur de chaque bâtonnet dans le graphique. Pour le faire nous allons simplement ajouter du texte en haut des bâtonnets.

let label = svg
    .selectAll("text")
    .data(data_set)
    .enter()
    .append("text")
    .text(function(d){
        return(d);
    })
    .attr("x", function(d,i){
        return(i * (width / data_set.length) + (width / data_set.length) / 2);
    })
    .attr("y", function(d){
        return(height - d );
    });

Avec l'interactivité vu précédemment vous pouvez faire en sorte que le label soit visible seulement au survol de la souris.
Lien CodePen.

Données

Jusqu'à présent nous avons travaillé avec des données dans un tableau à une dimension.

let data_set = [5,10,15]

Maintenant nous allons voir comment utiliser un tableau avec des objets qui contiennent les informations nécessaires pour refaire le même histogramme que jusqu'à présent.

let data_obj = [
    {x : 0,
    y : 5},
    {x : 1,
    y : 10},
    {x : 2,
    y : 15}
];

Même avec les données sous cette forme, c'est aussi simple qu'avant il suffit de bien indiquer l'endroit où chercher l'information.

let bar_obj = svg
    .selectAll("rect")
    .data(data_obj)
    .enter()
    .append("rect")
    .style("x", function(d){
        return(d.x * (width / data_obj.length) );
    })
    .style("y", function(d){
        return(height - d.y);
    })
    .style("width", width / data_obj.length - 1)
    .style("height", function(d){
        return(d.y);
    })
    .style("fill","blue");

Comme vous pouvez le voir nous n'avons rien changé à notre graphique autre que le fait que nous n'utilisons plus l'index car nous avons des données sous la forme (x,y).
Lien CodePen.

Echelles

Jusqu'à maintenant nous nous sommes contentés d'afficher les données sans se soucier des échelles. Elles sont utiles pour l'affichage des données dans notre svg car pour tout afficher dans l'espace limité qu'est le svg il faut tout proportionner afin de pouvoir afficher toutes les données des plus grandes au plus petites. Pour définir une échelle en d3 il nous faut définir le domaine de nos données, c'est à dire la plage de données comprises entre la valeur la plus petite et la valeur la plus élevée des données. Et nous avons besoin de définir aussi la zone du svg que nous allons utiliser pour le graphique.

Echelle linéaire

L'échelle linéaire est l'échelle que nous allons utiliser le plus souvent et c'est l'échelle que tout le monde connaît, elle est composée d'une suite de nombres qui se suivent. Prenons nos données définies précédemment pour créer les échelles de notre graphique, n'oubliez pas qu'un graphique a deux échelles une x et une y. Nous allons le faire de manière statique, nous connaissons toutes nos données.

let x_scale = d3
    .scaleLinear()
    .domain([0 , 3])
    .range([0 , 1000]);
let y_scale = d3
    .scaleLinear()
    .domain([20,0])
    .range([0,500]);

Pour l'échelle de l'axe y le domaine est inversé. Maintenant appliquons l'échelle définie précédemment à nos données, il suffit juste de faire appel à la variable que nous avons créee comme nous faisons appel à une fonction avec comme argument la donnée utilisée.

let bar_obj = svg
    .selectAll(".rect")
    .data(data_obj)
    .enter()
    .append("rect")
    .style("x", function(d){
        return(x_scale(d.x));
    })
    .style("y", function(d){
        return(y_scale(d.y));
    })
    .style("width", width / data_obj.length)
    .style("height", function(d){
        return(height - y_scale(d.y));
    })
    .style("fill","blue");

Lien CodePen.

Echelle dynamique

Nous avons nous même défini les valeurs minimales et maximales de nos échelles mais dans la plupart des cas nous ne pouvons pas le faire pour de multiples raisons, alors automatisons celà.

    .domain([d3.min(data, function(d){return(d.x);}),
        d3.max(data, function(d){return(d.x);})]);
        //ou bien
    .domain(d3.extent(data, function(d){return(d.x);}));

N'essayez pas avec nos données (data_obj) ça ne va pas fonctionner du fait qu'il n'y a pas assez de données. d3.extent() est à utiliser avec les données non numériques.

Echelle de temps

Si jamais nous voulons utiliser des dates à la place des nombres sur un axe nous avons une fonction prédéfinie en d3, trés semblable à l'échelle précédente. Mais avant de l'utiliser nous devons transformer nos données dans le bon format.

let parseTime = d3.timeParse("%Y");
time_data.forEach(function(d){
    d.year = parseTime(d.year);
});
let time_scale = d3
    .scaleTime()
    .range()
    .domain();

Lien CodePen.

Echelle ordinale

Contrairement à ce que nous avons vu jusqu'à présent avec un domaine et une partie du svg nécesaire pour définir l'échelle, nous n'avons pas besoin de l'un ni de l'autre. Ici nous n'utilisons pas les données mais plutôt un tableau avec les élements qui nous intéressent et que nous allons utiliser pour définir "la plage de données", et si nous définissons un domaine il y aura une relation directe entre les deux. exemple :

let ordinal_scale = d3
    .scaleOrdinal()
    .domain([1, 2, 3, 4, 5])
    .range(["one", "two", "three", "four", "five"]);
ordinal_scale(1); //"one"
ordinal_scale(3); //"three"

Nous utilisons souvent ce type d'échelle pour jouer avec les couleurs, pour créer des axes avec du texte, ...
Lien CodePen.

Echelle à bandes

L'échelle à bandes est fortement utilisée pour la création d'histogrammes car elle nous fourni la largeur optimale des bâtonnets en fonction de l'espace disponible pour le graphique et en fonction de la quantité de données. De ce fait nos histogrammes vont avoir un rendu optimisé. Ses paramètres sont identiques pour l'échelle linéaire, le seul changement est au niveau du domaine, nous devons lui donner toutes les données sous la forme d'un tableau, on utilisera un .map.

let band_scale = d3
    .scaleBand()
    .domain(data_obj.map(function(d){return(d.x);}))
    .range([0 , width]);

Nous avons parlé du fait que la taille des bâtonnets de l'histogramme nous est donné par l'échelle.

.style("width", width / data_obj.length) //Jusqu'à présent
.style("width", band_scale.bandwidth()) //Avec l'échelle à bandes

Lien CodePen.

Autres échelles

Il existe d'autres échelles définie dans d3, comme l'échelle logarythmique. Elles sont toutes définies et fonctionnent de la même manière que nous avons vu précédemment. Toutes les fonctions liées aux échelles n'ont pas été expliquées, à vous de décrouvrir les autres.

Afficher l'échelle

Nous avons vu comment définir les échelles, maintenant nous allons voir comment les afficher dans notre svg. Mais en premier lieu il faut faire de la place pour les afficher dans le svg, nous allons donc définir des margins.

let margin ={
    "top" : 20,
    "right" : 20,
    "bottom" : 20,
    "left" : 20
    };

Voyons ce qui va changer pour nous si nous rajoutons des margins à notre svg.

let band_scale = d3
    .scaleBand()
    .domain(data_obj.map(function(d){return(d.x);}))
    .range([margin.left , width - margin.right]);
let y_scale = d3
    .scaleLinear()
    .domain([20,0])
    .range([margin.top , height - margin.bottom]);
let bar_obj = svg
    .selectAll(".rect")
    .data(data_obj)
    .enter()
    .append("rect")
    .style("x", function(d){
        return(band_scale(d.x));
    })
    .style("y", function(d){
        return(y_scale(d.y));
    })
    .style("width", band_scale.bandwidth())
    .style("height", function(d){
        return(height - margin.bottom - y_scale(d.y));
    })
    .style("fill","blue");

Maintenant créons nos axes et ajoutons-les sur le svg.

let x_axis = d3
    .axisBottom(band_scale);
svg
    .append("g")
    .attr("transform", "translate(0 ," + (height - margin.bottom) + ")")
    .call(x_axis);
let y_axis = d3
    .axisLeft(y_scale);
svg
    .append("g")
    .attr("transform", "translate(" + margin.left + ",0)")
    .call(y_axis);

Nous définissons l'axe en fonction de l'échelle et nous indiquons dans quels sens doit se faire l'écriture de l'échelle, informations vers le bas/haut/droite/gauche. Et ensuite avec une translation nous la mettons au bon endroit lors de son ajout sur le svg.
Lien CodePen.

Graphique linéaire

Maintenant que nous savons faire des histogrammes nous allons passer aux graphiques linéaires. Nous allons réutiliser tout ce que nous avons appris sur les échelles, c'est valable pour tous les types de graphiques. Aprés avoir créee le svg, définit les échelles et ajouté les axes, nous devons définir comment nous allons déssiner notre ligne, point par point.

let line_graph = d3
    .line()
    .x(function(d){
        return(x_scale(d.x));
    
    })
    .y(function(d){
        return(y_scale(d.y));
    });

Ensuite il suffit de faire comme en Canvas, créer un chemin qui parcourt nos points un à un afin de créer notre ligne.

svg
    .append("path")
    .attr("d",line_graph(data_obj))

Lorsque nous appelons la fonction line_graph, nous lui donnons comme argument l'objet qui contient nos données. Il est important de lui donner un objet car lors de la déclaration de line_graph, nous avons fourni les clés afin d'avoir les données souhaitées. Voila, notre ligne est présente, mais elle est invisible pour le moment car nous n'avons défini aucune couleur.

    .style("stroke","green")
    .style("stroke-width", 1)
    .style("fill", "none");

Nous allons voir plus tard comment réaliser un graphique avec une multitude de lignes.
Lien CodePen.

Diagramme circulaire

Le diagramme circulaire est défini différemment des graphiques précédents car nous n'allons plus utiliser des coordonnées pour définir des points que nous allons exploiter afin d'avoir une représentation graphique. Nous allons utiliser des arcs de cercle. Nous allons devoir tout définir d'une autre manière. Commençons par le svg, le premier changement, nous allons déplacer nos axes au centre.

let svg = d3
    .select("body")
    .append("svg")
    .style("width", width)
    .style("height", height)
    .append("g")
    .attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");

Maintenant que nous avons un élément au centre du svg, nous allons délimiter la taille de notre diagramme à l'aide de deux rayons, un pour l'extérieur du cercle, la limite extérieure du diagramme et l'autre pour l'intérieur du diagramme, O si nous voulons un diagramme plein (Camenbert) et une valeur positive si nous voulons un diagramme avec le centre vide (donut).

let radius = Math.min(width, height) / 2;
let arc = d3
    .arc()
    .innerRadius(0)
    .outerRadius(radius);

Comme vu au début du tutoriel, il nous reste à définir un angle de début et un angle de fin pour nos arcs de cercle. La librairie d3 possède une fonction idéale pour cette situation, elle va nous générer toutes les données dont nous avons besoin à partir de nos données.

let pie = d3
    .pie()
    .sort(null)
    .value(function(d){
        return(d.y);
    });

La fonction sort(), trie nos données par ordre croissant, nous lui donnons la valeur null si nous n'avons pas besoin d'effectuer ce tri. Voila nous avons tous les éléments du puzzle pour construire notre diagramme circulaire.

let graph = svg
    .selectAll("arc")
    .data(pie(data_obj))
    .enter()
    .append("path")
    .attr("d",arc)
    .style("fill", "blue") 
    .style("stroke","black"); //Séparation entre les différentes parties.

Lien CodePen.

Label

Comme vu précédemment, nous pouvons afficher des informations dans notre graphique pour rendre celui ci plus facile à lire. Nous allons procéder de la même manière que nous l'avons fait pour l'histogramme à la différence que puisque nous travaillons avec des arcs de cercle nous allons en ajouter un spécialement pour le label.

let label_arc = d3
    .arc()
    .innerRadius(radius - 20)
    .outerRadius(radius - 20);

Nous avons défini un nouvel arc de cercle plus petit que notre graphique, et puisque nous voulons que tout soit sur un cercle, les rayons doivent faire la même taille. Maintenant nous allons juste afficher les valeurs de nos données au centre des arcs de cercle créés par nos données.

let label_text = svg
    .selectAll("text")
    .data(pie(data_obj))
    .enter()
    .append("text")
    .attr("transform", function(d){
        return("translate(" + label_arc.centroid(d) + ")");
    })
    .text(function(d){
        return(d.data.x);
    });

Lien CodePen.

Regroupement des données

Jusqu'à présent nous avons utilisé des données sous la forme d'objets, avec seulement deux informations, nos coordonnées. Malheureusement ce type de donnée nous limite dans la représentation, Nous allons donc passer à la vitesse supérieure et voir comment faire des graphiques avec plusieurs lignes par exemple. Premièrement nous allons avoir des données sous cette forme.

let data_complete = [
    {"Client": "ABC",
    "y" : 202,
    "x" : 2000},
    {"Client": "ABC",
    "y" : 215,
    "x" : 2002},
    {"Client": "ABC",
    "y" : 179,
    "x" : 2004},
    {"Client": "ABC",
    "y" : 199,
    "x" : 2006},
    {"Client": "XYZ",
    "y" : 100,
    "x" : 2000},
    {"Client": "XYZ",
    "y" : 215,
    "x" : 2002},
    {"Client": "XYZ",
    "y" : 179,
    "x" : 2004},
    {"Client": "XYZ",
    "y" : 199,
    "x" : 2006}
    ];

Avec ce que nous avons vu jusqu'à présent nous ne pourrions pas exploiter nos données pour une quelconque représentation graphique. Avec d3 nous allons réorganiser nos données à l'aide de la fonction .nest(), qui a besoin d'une clé et des données pour nous réorganiser le tout en fonction de la clé que nous allons lui donner.

let useful_data = d3
    .nest()
    .key(function(d){
        return(d.Client);
    })
    .entries(data_complete);

Nos données sont sous la forme suivante à partir de maintenant:

useful_data = [
    {"key" : "ABC",
    "values" : [
        {"Client": "ABC",
        "y" : 202,
        "x" : 2000},
        {"Client": "ABC",
        "y" : 215,
        "x" : 2002},
        {"Client": "ABC",
        "y" : 179,
        "x" : 2004},
        {"Client": "ABC",
        "y" : 199,
        "x" : 2006}
        ]
    },
    {"key" : "XYZ",
    "values" : [
        {"Client": "XYZ",
        "y" : 100,
        "x" : 2000},
        {"Client": "XYZ",
        "y" : 215,
        "x" : 2002},
        {"Client": "XYZ",
        "y" : 179,
        "x" : 2004},
        {"Client": "XYZ",
        "y" : 199,
        "x" : 2006}
        ]
    }];

Avec les données sous cette forme nous pouvons créer nos représentations graphiques, car nos données sont disposées d'une manière similaire à ce que nous avons vu précédemment, un objet avec des coordonnées x et y. Nous devons juste parcourir nos données "Client" par "Client" et ajouter son graphique au svg utilisé. Nous allons utiliser .forEach pour parcourir nos données.Voyons ce que cela donne en pratique.

useful_data.forEach(function(d,i){
    svg
        .append("path")
        .attr("d",line_graph(d.values))
        .style("stroke","red")
        .style("stroke-width", 1)
        .style("fill", "none");
});

Voici la dérnière fonction que nous allons aborder dans ce tutoriel.
Lien CodePen.

Conclusion

Nous arrivons à la fin de notre parcourt, j'espère qu'il vous a été utile et que ça vous a permis à comprendre et apprécier cet outil complet et complexe qu'est d3.

Mot de l'auteur

Je me suis lancé dans la création de ce tutoriel car au cours d'un challenge d'une semaine je n'ai pas pu comprendre comment fonctionnait d3. De plus je suis quelqu'un qui aime les défis alors autant partager avec tout le monde un tutoriel complet, car je n'ai rien trouvé qui puisse expliquer la librairie de d3 du début jusqu'à la fin.

Fonctions d3

Dans cette section vous allez retrouver toutes les fonctions utilisées durant le tutoriel avec tout ce qu'il faut pour mieux comprendre le fonctionnement.

  • d3 => appel à la librairie d3

  • .select() => sélection, pareil qu'en CSS, d'un élément du DOM

  • .selectAll() => sélection de plusieurs éléments du DOM, s'ils n'existent pas la fonction les considére comme un ajout futur et les ajoute à la suite de ceux sélectionnés

  • .append() => création d'un élément du DOM

  • .text() => string inséré dans l'élément généré avec append()

  • .data() => sélection des données

  • .enter() => début d'une boucle qui parcourt tous les éléments de data()

  • .attr("attribute", "valeur") => ajout d'un attribut HTML

  • .style("propertie", "value") => ajout d'une propriété CSS

  • .on("event",function) => lance une fonction si un événement se produit

  • .domain() => plage de données qui contient la plus petite et la plus grande valeur des données, les arguments doivent être des entiers

  • .range() => partie du svg utilisée pour le graphique

  • function(d){return(d);} => fonction anonyme renvoie l'élément(d) parcouru par enter()

  • function(d,i){return(d,i);} => pareil que la fonction précédente avec l'index(i) de l'élément en plus