javascript - R networkD3 sankey - 为节点标签添加值

标签 javascript r d3.js htmlwidgets networkd3

使用 networkD3::sankeyNetwork() 创建 Sankey 图表的示例代码...

library("networkD3")

a = read.csv(header = TRUE, text = "
date,Data Center,Customer,companyID,source,target,value 
")

node_names <- unique(c(as.character(a$source), as.character(a$target)))
nodes <- data.frame(name = node_names)
links <- data.frame(source = match(a$source, node_names) - 1,
                    target = match(a$target, node_names) - 1,
                    value = a$value)

p <- sankeyNetwork(Links = links, Nodes = nodes, Source = "source",
              Target = "target", Value = "value", NodeID = "name",
              sinksRight = FALSE)

onRender(
  p,
function(el,x){
  // select all our node text
  var node_text = d3.select(el)
    .selectAll(".node text")
    .attr("x", 6 + x.options.nodeWidth)
    .attr("text-anchor", "start");
}

)

我想在节点标签旁边显示总数(每个节点的 sum(value) 结果)。我在 StackOverflow 上找到了这篇文章,并尝试根据该文章中的答案模拟一些 JavaScript 代码,但我无法使其工作。 Place text values to right of sankey diagram

最佳答案

jsCode htmlwidgets::onRender() 的参数是包含有效 JavaScript 的字符串/字符向量。

library(networkD3)

a = read.csv(header = TRUE, text = "
date,Data Center,Customer,companyID,source,target,value 
6/1/2021,dcA,customer1,companyID1,open_list_view_1,open_card_2,1 
6/1/2021,dcA,customer1,companyID1,open_card_2,edit_card_3,1
6/1/2021,dcA,customer1,companyID1,edit_card_3,save_card_4,1 
6/1/2021,dcA,customer1,companyID1,save_card_4,back_to_card_list_5,2 
6/1/2021,dcA,customer1,companyID1,back_to_card_list_5,show_more_6,1
6/1/2021,dcA,customer1,companyID1,show_more_6,view_introduction_7,1
6/1/2021,dcA,customer1,companyID1,view_introduction_7,scroll_down_8,2
6/2/2021,dcA,customer2,companyID2,open_list_view_1,open_card_2,3
6/2/2021,dcA,customer2,companyID2,open_card_2,edit_card_3,1
6/2/2021,dcA,customer2,companyID2,edit_card_3,save_card_4,4
6/2/2021,dcA,customer2,companyID2,save_card_4,back_to_card_list_5,2 
6/2/2021,dcA,customer2,companyID2,back_to_card_list_5,show_more_6,1
6/2/2021,dcA,customer2,companyID2,show_more_6,view_introduction_7,1
6/2/2021,dcA,customer2,companyID2,view_introduction_7,scroll_down_8,5
")

node_names <- unique(c(as.character(a$source), as.character(a$target)))
nodes <- data.frame(name = node_names)
links <- data.frame(source = match(a$source, node_names) - 1,
                    target = match(a$target, node_names) - 1,
                    value = a$value)

p <- sankeyNetwork(Links = links, Nodes = nodes, Source = "source",
                   Target = "target", Value = "value", NodeID = "name",
                   sinksRight = FALSE)

javascript_string <- 
  'function(el, x){
    d3.select(el).selectAll(".node text")
      .text(d => d.name + " (" + d.value + ")");
  }'

htmlwidgets::onRender(x = p, jsCode = javascript_string)

enter image description here

关于javascript - R networkD3 sankey - 为节点标签添加值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71264918/

相关文章:

javascript - 在Jquery中获取所选图像的值

r - 文本分析: What after term-document matrix?

r - 使用 geom_text,将 ggplot 中标签的长度微移一半

d3.js - d3 基本追加示例不起作用

javascript - 如何在 D3.js 中的弧线之间绘制简单的线条(流)?

javascript - 通过 onclick 事件将 value 属性数据从 HTML 端传递到 JavaScript 函数

php - 如何在字符串中找到字母数字

javascript - 如何实现点从a到b的移动过渡

javascript - 如何在固定的 div 中显示图像以制作可滚动的图像面板?

r - 使用 R 中的函数调用对象