0

在 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

4

1 回答 1

0

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

因此,只需通过以下方式解决:

install.packages('DT')
packageVersion('DT')
# [1] ‘0.4’
于 2018-03-02T12:45:19.487 回答