首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >显示(),隐藏()使用从shinyjs,发亮

显示(),隐藏()使用从shinyjs,发亮
EN

Stack Overflow用户
提问于 2016-03-10 15:37:32
回答 1查看 10K关注 0票数 5

我有一个我开发的闪亮应用程序的简化版本。我想要的是能够在按下dataframe1操作按钮时显示Frame1,并隐藏dataframe2,并在Frame2操作按钮被按下时再次显示dataframe2,并隐藏dataframe1。显然,我需要在同一地点打印这些桌子。感谢您的帮助和时间。

server.R

代码语言:javascript
复制
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

代码语言:javascript
复制
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"))
              )
  )
)
)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-21 08:44:19

正如@Dean友好地指出的那样,这些函数与其他包使用相同的命名空间,从而使它们无法执行其功能。

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

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35920878

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档