show(), hide() 用法来自 shinyjs, Shiny

show(), hide() usage from shinyjs, Shiny

我开发了一个闪亮的应用程序的简化版本。我想要的是能够在按下 Frame1 操作按钮时显示 dataframe1 并隐藏 dataframe2,并在按下 Frame2 操作按钮时再次显示 dataframe2 并隐藏 dataframe1。显然,我需要在同一位置打印表格。感谢您的帮助和抽出时间。

server.R

shinyServer(function(input, output, session) {

  data_for_use <- reactiveValues(d=NULL)

  observeEvent(input$actForFrame1,{
  data_for_use$dataFrame1 <- data.frame(firstColumn= c(1,3,5),secondColumn=c(2,4,6))})

  observeEvent(input$actForFrame2,{
  data_for_use$dataFrame2 <- data.frame(firstColumn= c(10,30,50),secondColumn=c(20,40,60))})

  output$dataFrame1 <- DT::renderDataTable({
    DT::datatable(data_for_use$dataFrame1)
  })

  output$dataFrame2 <- DT::renderDataTable({
    DT::datatable(data_for_use$dataFrame2)
  })

  observeEvent(input$actForFrame1,{
    show("dataFrame1")
    hide("dataFrame2")

  })

  observeEvent(input$actForFrame2,{
    show("dataFrame2")
    hide("dataFrame1")

  }) 
})

ui.R

library(shinyjs)
library(shiny)
library(DT)

shinyUI(pageWithSidebar(

  headerPanel("Test"),

  sidebarPanel(

    actionButton("actForFrame1", "Frame1"),
    actionButton("actForFrame2", "Frame2")
  ),

  mainPanel(
    useShinyjs(),
    wellPanel("Test",
              conditionalPanel(condition = "input.actForFrame1",
              DT::dataTableOutput("dataFrame1")
              ),
              conditionalPanel(condition= "input.actForFrame2",
              DT::dataTableOutput("dataFrame2"))
              )
  )
)
)

事实证明,正如@Dean Attali 友好地指出的那样,这些函数与其他一些包使用相同的命名空间,这反过来又导致它们无法执行它们的功能。

使用 shinyjs::show(); shinyjs::hide() 解决了这个问题。