条件renderDataTable

时间:2020-02-27 11:51:12

标签: r shinyapps

在应用程序中,如果我按下“ key.a”按钮,有两个操作按钮“ tasto.a”和“ tasto.b” data.frame“ a”被分配给tab.SDO()按下“ key.a”按钮,将data.frame“ a”分配给tab.SDO(),以便在ui中呈现所选的data.frame。问题是,即使我按下“ key.b”键,也仅在列表中进行第二次分配(tab.SDO <-eventReactive(输入$ key.b,{b}))。这种“条件”分配是正确的还是我犯了一些错误?

require(shiny)

a <- data.frame(a.x = c(1,3,4,5,1,2), a.y = c("A", "A", "B", "B", "C", "C"))
b <- data.frame(b.x = c(21,33,44,52,13,27), b.y = c("D", "D", "E", "E", "F", "F"))


#### UI ####
ui <- navbarPage(title = "FLUSSI SANITARI",
                 theme = shinytheme("cerulean"),     
                 #### Schede di dimissione ospedaliera ####
                 tabPanel(title = "prova", 
                          sidebarLayout(
                            sidebarPanel(
                              actionButton("tasto.a", "a"),
                              actionButton("tasto.b", "b")
                            ),
                            mainPanel(
                              div(DT::dataTableOutput("tabella.SDO"), style = "font-size:80%")
                            )
                          )

                 )
)

#### SERVER ####
server <- function(input, output, session) {

  tab.SDO <- eventReactive(input$tasto.a, {a})
  tab.SDO <- eventReactive(input$tasto.b, {b})


  output$tabella.SDO <- DT::renderDataTable({tab.SDO()}, rownames = FALSE,
                                            options = list(pageLength = 25)
  )


}

# Run the application 
shinyApp(ui = ui, server = server)

1 个答案:

答案 0 :(得分:0)

您可以使用反应性值和一些observeEvent

server <- function(input, output, session) {

  tab.SDO <- reactiveVal(a)
  observeEvent(input$tasto.a, {
    tab.SDO(a)
  })
  observeEvent(input$tasto.b, {
    tab.SDO(b)
  })

  output$tabella.SDO <- DT::renderDataTable({tab.SDO()}, rownames = FALSE,
                                            options = list(pageLength = 25)
  )

}