6

我正在开发一个使用多个 html 小部件的 R 闪亮应用程序,特别是networkD3d3heatmapchorddiag

这些小部件单独工作正常。但是,在同一页面中使用它们会在它们应该存在的地方留下空白。

这是显示错误的可重现代码。UI 中的注释绘图行,您将看到绘图出现和消失。

我非常感谢您的帮助!

# libraries
library(shiny)
library(d3heatmap)
library(chorddiag)
library(networkD3)

# Server
server <- function(input, output) {

  # create heatmap
  output$heatmap <- renderD3heatmap({
    d3heatmap(mtcars, scale = "column", colors = "Spectral")
  })

  # create chord diagram
  output$chord <- renderChorddiag({
    m <- matrix(c(11975,  5871, 8916, 2868,1951, 10048, 2060, 6171, 8010, 16145, 8090, 8045,1013,   990,  940, 6907),
    byrow = TRUE, nrow = 4, ncol = 4)
    haircolors <- c("black", "blonde", "brown", "red")
    dimnames(m) <- list(have = haircolors, prefer = haircolors)
    groupColors <- c("#000000", "#FFDD89", "#957244", "#F26223")
    chorddiag(m, groupColors = groupColors, groupnamePadding = 20)
  })

  # create sankey
  output$sankey <- renderSankeyNetwork({
    nodes=data.frame(ID=c("A","B","C","D","E"))
    links=data.frame(source=c(1,2,3), target=c(3,4,4), value=c(12,15,29))
    sankeyNetwork(Links = links, Nodes = nodes, Source = "source", Target = "target", Value = "value", NodeID = "ID")
  })

}



# Ui
ui <- fluidPage(
  sidebarLayout(
    sidebarPanel("shiny shines"),
    mainPanel(
        # Comment these lines and you will see charts appear / disappear.
        d3heatmapOutput("heatmap"),
        chorddiagOutput("chord"),
        sankeyNetworkOutput("sankey")
    )
  )
)

shinyApp(ui = ui, server = server)
4

2 回答 2

3

networkD3已在 2017 年 2 月的0.3 版中更新为 D3v4 ,它与 D3 的 v3 版本不兼容,而这chorddiag似乎d3heatmap是使用的。htmlwidgets,它是驱动上述包的底层包,仅使用最新版本的依赖项,因此使用同一库的冲突版本的 htmlwidget 不能同时工作。在这里查看有关此问题的讨论起点。

你有几个可能的选择,虽然它们都不是很好......

  1. 恢复networkD3到 < 0.3 的版本,以便它也使用 D3v3

  2. chorddiag开发者大厅和d3heatmap开发者升级到 D3v4

  3. 游说htmlwidgets开发人员想出一种强大的方法来处理冲突的 JavaScript 依赖项

于 2017-09-18T08:23:15.980 回答
1

@CJYetman 提供了 3 个选项来处理这个问题。这里还有一个,虽然它仍然不吸引人,但可能工作量更少:将使用的库chorddiagd3heatmapfrom重命名d3为其他内容,以便 D3 的版本 3(由这两个使用)和版本 4(由 使用networkD3)可以在同一页。

这样做的第一步chorddiag是在这里: https ://github.com/dmurdoch/chorddiag 。它将库重命名为d3_3. 同样的更改似乎也适用于d3heatmap; 见https://github.com/dmurdoch/d3heatmap

于 2019-12-23T16:26:22.403 回答