6

我对 d3.js 可视化数据的简洁性感到惊讶。隐藏在这种简洁下的复杂性也让人有点难以理解它是如何工作的。以下是来自http://mbostock.github.com/d3/ex/calendar.html的部分代码

问题是它如何在创建的 svg 数量内创建一天的矩形(var svg = d3 ....)。在声明中svg.selectAll("rect.day"),我不确定它如何为每个 svg 附加 rect(selectAll 试图选择 rect.day !)

var margin = {top: 19, right: 20, bottom: 20, left: 19},
    width = 960 - margin.right - margin.left, // width
    height = 136 - margin.top - margin.bottom, // height
    cellSize = 17; // cell size

var day = d3.time.format("%w"),
    week = d3.time.format("%U"),
    percent = d3.format(".1%"),
    format = d3.time.format("%Y-%m-%d");


var svg = d3.select("#chart").selectAll("svg")
    .data(d3.range(1990, 2011))
  .enter().append("svg")
    .attr("width", width + margin.right + margin.left)
    .attr("height", height + margin.top + margin.bottom)
    .attr("class", "RdYlGn")
  .append("g")
    .attr("transform", "translate(" + (margin.left + (width - cellSize * 53) / 2) + "," + (margin.top + (height - cellSize * 7) / 2) + ")");

var rect = svg.selectAll("rect.day")
    .data(function(d) { return d3.time.days(new Date(d, 0, 1), new Date(d + 1, 0, 1)); })
  .enter().append("rect")
    .attr("class", "day")
    .attr("width", cellSize)
    .attr("height", cellSize)
    .attr("x", function(d) { return week(d) * cellSize; })
    .attr("y", function(d) { return day(d) * cellSize; })
    .datum(format);
4

1 回答 1

8

你看过Thinking With Joins吗?它非常清楚地解释了数据连接的工作原理——本质上,在 D3 中,您使用.selectAll()将数据连接到选择中,然后根据.enter()需要添加新元素。所以

svg.selectAll("rect.day")
    .data( ... )
  .enter().append("rect")
    .class("day")

根据数据创建新rect元素。

于 2012-09-06T23:15:15.980 回答