R Shiny在多个标签

时间:2017-06-13 08:57:52

标签: r shiny

我构建了一个带有多个标签的R Shiny应用程序,它们有一些共同的过滤器。目前,所有过滤器都是独立的,不会跨多个标签同步。因此,当我从值" a"更改selectInput1时为了重视" b",我必须在下一个包含selectInput2的选项卡上重复此处理,该选项包含相同的选项/含义。

我想过使过滤器动态化,因此使用R Shiny的服务器端渲染它们。当然,我总是可以使selectInput2等于selectInput1。但是如果用户更改selectInput2而不是selectInput1会怎样?它在逻辑中创建了一种循环。

我花了很多时间为这个问题找到解决方案,不知怎的,我确定我不是第一个遇到这个问题的人。建议或有用的链接真的很有帮助!

示例:

## UI.R
shinyUI(
  dashboardPage("Dashboard",

    # Create tabs
    tabPanel("Start",
             p("This is the frontpage")
    ),
    tabPanel("tab1",
             uiOutput("selectInput1")
    ),
    tabPanel("tab2",
             uiOutput("selectInput2")
    )
  )
)

## Server.R
library(shiny)

shinyServer(function(input, output,session){
  output$selectInput1 <- renderUI({
    selectInput(inputId = "id1", 
                label = "select", 
                choices = c("a","b","c"), 
                selected = "a")
  })

  output$selectInput2 <- renderUI({
    selectInput(inputId = "id2", 
                label = "select", 
                choices = c("a","b","c"), 
                selected = "a")
  })
})

1 个答案:

答案 0 :(得分:4)

我个人会使用单个输入控件来控制不同的选项卡面板。一种方法是在您的标签下包含该单个输入:

shinyApp(
  fluidPage(
    fluidRow(
      tabsetPanel(
        tabPanel("Tab1",
                 verbatimTextOutput("choice1")),
        tabPanel("Tab2",
                 verbatimTextOutput("choice2"))
      )
    ),
    fluidRow(
      selectInput("id1", "Pick something",
                  choices = c("a","b","c"),
                  selected = "a")
    )
  ),
  function(input, output, session){
    output$choice1 <- renderPrint(input$id1)
    output$choice2 <- renderPrint({
      paste("The choice is:", input$id1)
    })
  }
)

或者,当您使用shinydashboard时,您实际上可以在侧边栏中添加该控件,如果必须,可以再次在一组选项卡下的自己的行中添加。

我想不出有多个输入可以自动选择同一个东西的理由。除了减慢你的应用程序,我看不到任何收获。但是,如果您坚持,则使用reactiveVal将所选选项设为无效值,并使用例如observeEvent()来更新该无效值。使用shinydashboard的一个小例子:

library(shinydashboard)
library(shiny)
ui <- shinyUI(
  dashboardPage(title = "Dashboard",
                dashboardHeader(),
                dashboardSidebar(
                  tabsetPanel(
                  tabPanel("tab1",
                           uiOutput("selectInput1")
                  ),
                  tabPanel("tab2",
                           uiOutput("selectInput2")
                  )
                )),
                dashboardBody(
                  verbatimTextOutput("selected")
                )
  )
)

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

  thechoice <- reactiveVal("a")  
  output$selectInput1 <- renderUI({
    selectInput(inputId = "id1", 
                label = "select", 
                choices = c("a","b","c"), 
                selected = thechoice())
  })
  output$selectInput2 <- renderUI({
    selectInput(inputId = "id2", 
                label = "select", 
                choices = c("a","b","c"), 
                selected = thechoice())
  })

  observeEvent(input$id2,{
    thechoice(input$id2)
  })

  observeEvent(input$id1,{
    thechoice(input$id1)
  })

  output$selected <- renderPrint({
    c(input$id1, input$id2)
  })
})

shinyApp(ui, server)