R Shiny,在调用模块中的DT :: replaceData不起作用

时间:2018-03-01 17:22:46

标签: r shiny dt modularization

在R Shiny应用程序中,我尝试使用DT::replaceData更新要显示的数据,并保留当前状态(例如过滤)。 虽然它适用于一个简单的闪亮应用程序,但当我模块化应用程序并从callModule调用时,它不会。

在下面的示例中,选择顶部框中的物种应该触发替换数据以显示如下。

这是一个有效的例子:

library(shiny)

ui <- fluidPage(
  selectInput('species', 'Choose Species',
              choices=unique(iris$Species),
              selected=unique(iris$Species), multiple=TRUE),
  DT::dataTableOutput('dt')
)

server <- function(input, output, session) {
  output$dt <- DT::renderDataTable({
    DT::datatable(
      iris, filter='top',
      options = list(autoWidth=TRUE)
    )
  })

  observeEvent(is.null(input$species), {
    DT::replaceData(
      DT::dataTableProxy('dt'),
      dplyr::filter(iris, Species %in% input$species)
    )
  })
}

shinyApp(ui, server)

这是模块化版本无效:

library(shiny)

ui <- function(id) {
  ns <- NS(id)
  tagList(
    selectInput(ns('species'), 'Choose Species',
                choices=unique(iris$Species),
                selected=unique(iris$Species), multiple=TRUE),
    DT::dataTableOutput(ns('dt'))
  )
}

server <- function(input, output, session) {
  output$dt <- DT::renderDataTable({
    DT::datatable(
      iris, filter='top',
      options = list(autoWidth=TRUE)
    )
  })

  observeEvent(is.null(input$species), {
    print(input$species)
    DT::replaceData(
      DT::dataTableProxy('dt'),
      dplyr::filter(iris, Species %in% input$species)
    )
  })
}


mainUi <- fluidPage(ui('app'))
mainSrv <- function(input, output, session) {
  callModule(server, 'app')
}
shinyApp(mainUi, mainSrv)

我想知道为什么第二个例子不起作用,以及如果可能的话如何修复它。

更新

解决!

自DT v0.3起已修复。 请参阅:https://github.com/rstudio/DT/issues/357

1 个答案:

答案 0 :(得分:0)

自v3.0起已经解决了。 参考:https://github.com/rstudio/DT/issues/357

所以,简单地解决:

install.packages('DT')
packageVersion('DT')
# [1] ‘0.4’