直到observeEvent之后,更新输入功能才会生效

时间:2017-08-15 19:41:07

标签: r shiny

按下"测试箱"按钮应该导致observeEvent函数在更新滑块后打印出30然后再打印25和35,但是在updateSliderInput&之前和之后都会重复打印30。由于某种原因,observeEvent代码似乎不会处理滑块输入中的更改。

ui.R:

library(shiny)
shinyUI(fluidPage(
  titlePanel("Old Faithful Geyser Data"),
  sidebarLayout(
    sidebarPanel(
      sliderInput("bins",
                  "Number of bins:",
                  min = 1,
                  max = 50,
                  value = 30),
      actionButton("test","Test Bins")
    ),
    mainPanel(
      plotOutput("distPlot")
    )
  )
))

server.R:

library(shiny)
shinyServer(function(input, output, session) {
  output$distPlot <- renderPlot({
    x    <- faithful[, 2]
    bins <- seq(min(x), max(x), length.out = input$bins + 1)
    hist(x, breaks = bins, col = 'darkgray', border = 'white')
  })
  observeEvent(input$test,{
    print(input$bins)
    updateSliderInput(session,"bins",value=25)
    print(input$bins)
    updateSliderInput(session,"bins",value=35)
    print(input$bins)
  })
})

2 个答案:

答案 0 :(得分:2)

observeEvent功能结束之前,更改不会生效。如果需要在观察者中使用滑块的新值,则可以使用额外的变量。

在下面的示例中,您的代码经过修改,以显示在input$bins函数结束之前如何更新滑块(以及关联的observeEvent变量)。

library(shiny)

ui <- shinyUI(fluidPage(
  titlePanel("Old Faithful Geyser Data"),
  sidebarLayout(
    sidebarPanel(
      sliderInput("bins",
                  "Number of bins:",
                  min = 1,
                  max = 50,
                  value = 30),
      actionButton("test","Test Bins")
    ),
    mainPanel(
      plotOutput("distPlot")
    )
  )
))

server <- function(input, output, session){     
output$distPlot <- renderPlot({
    x    <- faithful[, 2]
    bins <- seq(min(x), max(x), length.out = input$bins + 1)
    hist(x, breaks = bins, col = 'darkgray', border = 'white')
  })
  observeEvent(input$test,{
    print(input$bins)
    value  <- 25
    updateSliderInput(session,"bins",value=value)
    cat("Slider updated to:", value, "\n")
    # simulate some complex process
    Sys.sleep(1)
    cat("Observer ends\n")
  })
  observeEvent(input$bins, {
    cat("Slider changed to:", print(input$bins), "\n")
  })
}

shinyApp(ui, server)  

答案 1 :(得分:2)

Geovany的回答非常有用。我还在以下位置查看了jcheng5的响应:https://github.com/rstudio/shiny/issues/1010,它帮助我更改了服务器,以便您可以在观察器中使用滑块的新值而无需添加额外的变量。服务器的改编代码:

response.forEach(function(project){
  $('#teamname').prepend('<option value='+project.teamname+'>'+project.teamname+'</option>\')
  console.log(project.teamname);
});
$("#teamname").formSelect();