当前位置: 首页 > 知识库问答 >
问题:

d3.js中的array_replace?

柴宝
2023-03-14

graph.csv:

source,target
1,2
1,3
1,4
2,5
2,6
11,22
14,21
3,7
3,8
4,9
4,10
5,11
5,12
5,13
6,14
6,15
7,16
8,17
9,18
10,19
10,20

nodes.csv:

node_id,node_name
1,Node1
2,Node2
3,Node3
4,Node4
5,Node5
6,Node6
7,Node7
8,Node8
9,Node9
10,Node10
11,Node11
12,Node12
13,Node13
14,Node14
15,Node15
16,Node16
17,Node17
18,Node18
19,Node19
20,Node20
21,Node21
22,Node22

到目前为止的代码是:

 

    var margin = {top: 40, right: 40, bottom: 40, left: 40}, width = 1024 - margin.left - margin.right, height = 768 - margin.top - margin.bottom;

    var tree = d3.layout.tree()
        .size([height, width]);

    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 + ")");

    d3.csv("graph.csv", function(links) {
        var nodesByName = {};

        links.forEach(function(link) {
            var parent = link.source = nodeByName(link.source),
            child = link.target = nodeByName(link.target);
            if (parent.children) parent.children.push(child);
            else parent.children = [child];
        });

    var nodes = tree.nodes(links[0].source);

    svg.selectAll(".link")
        .data(links)
        .enter().append("line")
        .attr("class", "link")
        .attr("x1", function(d) { return d.source.y; })
        .attr("y1", function(d) { return d.source.x; })
        .attr("x2", function(d) { return d.target.y; })
        .attr("y2", function(d) { return d.target.x; });

    svg.selectAll(".node")
        .data(nodes)
            .enter().append("circle")
       .attr("class", "node")
            .attr("r", 10)
            .attr("cx", function(d) { return d.y; })
            .attr("cy", function(d) { return d.x; });

    svg.selectAll("text")     
            .data(nodes)
       .enter().append("text")
       .attr("class", "label")
       .attr("x",function(d) { return (d.y - 25); })
       .attr("y",function(d) { return (d.x + 20); })
       .text("Text");

    function nodeByName(name) {
        return nodesByName[name] || (nodesByName[name] = {name: name});
    }
    });

编辑:我一直在寻找替换数组内容的技术,基于其他数组ans的内容,我在PHP中找到了一个漂亮的函数,它完成了我所需要的任务:ARRAY_REPLACE。现在我需要在JavaScript/D3.js中使用它,但我似乎可以找到完全相同的解决方案或类似的解决方案。有什么想法吗?

共有1个答案

益清野
2023-03-14

我认为最简单的方法是在您使用的地方直接将id映射到名称,如下所示:

svg.selectAll("text")
  [...]
  .text( function(d) { return namesMap[d.name]; });

假设namesmapnode_id转换为node_name

现在您只需创建前面提到的namesmap,例如如下所示:

d3.csv("nodes.csv", function(names) {
  var namesMap = {};
  names.forEach(function(d) {
    namesMap[d.node_id] = d.node_name;
  });
  // code using namesMap goes here
});
 类似资料:
  • D3(Data-Driven Documents 或 D3.js)是一个 JavaScript 库,用于使用 Web 标准将数据可视化。D3 帮助你使用SVG、 Canvas 和 HTML 将数据变为现实。D3 将强大的可视化和交互技术与数据驱动的DOM操作方法相结合,让你拥有现代浏览器的全部功能,并可以自由地为您的数据设计合适的可视化界面。

  • D3.js是一个JavaScript库,用于在浏览器中创建交互式可视化。 D3库允许我们在数据集的上下文中操纵网页的元素。 这些元素可以是HTML,SVG或Canvas元素,可以根据数据集的内容进行引入,删除或编辑。 它是一个用于操作DOM对象的库。 D3.js可以成为数据探索的宝贵帮助。 它使您可以控制数据的表示,并允许您添加数据交互性。 与其他库相比,D3.js是最重要的框架之一。 这是因为;

  • 本文向大家介绍d3.js 使用D3 js创建SVG元素,包括了d3.js 使用D3 js创建SVG元素的使用技巧和注意事项,需要的朋友参考一下 示例 尽管D3并非专门用于处理SVG元素,但它已广泛用于创建和处理基于SVG的复杂数据可视化。D3提供了许多强大的方法,可帮助轻松创建各种几何SVG结构。 建议首先了解SVG规范的基本概念,然后使用大量的D3 js示例创建可视化效果。 D3 JS范例 SV

  • 本文向大家介绍d3.js 元素,包括了d3.js 元素的使用技巧和注意事项,需要的朋友参考一下 示例 <rect> 代表矩形,除了笔触和填充之类的美学属性外,矩形还应通过位置和大小来定义。 至于位置,由x和y属性确定。该位置相对于矩形的父级。而且,如果您未指定x或y属性,则相对于父元素,默认值为0。 在指定位置或矩形的“起点”之后,接下来就是指定尺寸,如果您想在画布上实际绘制某东西,这是必不可少的

  • D3库中所有函数都在“d3”命名空间内。D3 使用语义版本命名。 你可以使用“d3.version”查看D3的最新版本。

  • 本文向大家介绍d3.js 坐标系,包括了d3.js 坐标系的使用技巧和注意事项,需要的朋友参考一下 示例 在正常的数学坐标系中,点x = 0,y = 0位于图形的左下角。但在SVG坐标系中,此(0,0)点位于“画布”的左上角,当您将位置指定为绝对/固定并使用顶部和左侧控制位置时,它有点类似于CSS。元素的确切点。 必须牢记的是,随着SVG中y的增加,形状会向下移动。 假设我们要创建一个散点图,每个