javascript - 使用 D3.js 创建矩形图表

标签 javascript html css d3.js svg

我正在尝试制作一个 d3 javascript,它创建一个颜色取决于数据集的矩形。所有的矩形都彼此相邻,例如:

         [][][][][][]
         [][][][][][]

我的脚本可以为我的所有数据创建矩形,但它会像这样溢出:

          [][][][][][][][][][][][][][][][][][][][][][][][][][][]

如何为我的 d3 脚本创建宽度和高度属性,使其看起来更像

        [][][][]
        [][][][]
        [][][][]

这是我的脚本:

    <script>
         //for whatever data set
         var data = [];
         //Make an SVG Container
     var svgContainer = d3.select("body").selectAll("svg")
                                 .data(data)
                                 .enter().append("svg")
                                 .attr("width", 38)
                                 .attr("height", 25);

    //Draw the rectangle
   var rectangle = svgContainer.append("rect")
                     .attr("x", 0)
                     .attr("y", 5)
                     .attr("width", 38)
                     .attr("height", 25);
    </script>

最佳答案

您必须更改 xy 属性。

.attr("x", function(d, i) {
    return 5 + (i%itemPerLine) * widthRect;
})
.attr("y", function(d, i) {
    return 5 + Math.floor(i/itemPerLine) * heightRect;
})

(itemPerLine 是每行rect 的个数)

参见 this fiddle例如

关于javascript - 使用 D3.js 创建矩形图表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39583209/

相关文章:

HTML/CSS 菜单悬停链接

html - 中心等距的空间 NavBar 元素?

jquery - 将鼠标悬停在表列、行和标题列上

javascript - JavaScript 执行后检查 DOM 是否处于稳定状态(无事件回流/重绘)

javascript - 使用 jQuery.getScript() 赋值后全局变量未定义

javascript - 使用 javascript/Jquery 动态创建一个 Div

html - 如何使用 CSS3 使我的背景图像显示在页眉中的文本后面?

html - 创建相框类型边框

javascript - 如何使用 php 从 html 行(在表中)获取数据

javascript - REST API和JWT身份验证: send data along token?