如何在有光泽的情况下使用observeEvent删除图表?

时间:2017-04-13 17:11:52

标签: r shiny flexdashboard

我在flexdashboard中使用闪亮的运行时。

我想在按下按钮(input$updt)时隐藏图表,我正在尝试这样做:

   ---
title: "Students Data - College of Business"
output: 
  flexdashboard::flex_dashboard:
      orientation: columns 

runtime: shiny
---
```{r setup, include=FALSE}
library(flexdashboard)
library(ggplot2)
library(shinyjs)
shinyjs::useShinyjs(rmd=TRUE)
```

Column {data-width=650}
-----------------------------------------------------------------------

### Chart A

```{r}

actionButton('updt', 'Update chart')
output$p1 <-renderPlot({ ggplot(diamonds, aes(carat, price)) + geom_point() }, height=800)
plotOutput("p1")

output$p2 <- renderPlot({
   ggplot(mtcars, aes(cyl, disp))+ geom_point()
})

plotOutput("p2")
observeEvent(input$updt, {hide("p1")})


```

但是,当我点击按钮时,它不会隐藏p1

1 个答案:

答案 0 :(得分:1)

hide()需要包含该图的元素的id,但renderPlot不允许在outputId中设置outputArgs

解决方法是使用plotOutput

library(shinyjs)
shinyjs::useShinyjs(rmd=TRUE)
actionButton('updt', 'Update chart')

output$p1 <- renderPlot({load('p1.RDA') p1}, height=800)
plotOutput("p1")
output$p2 <- renderPlot(expr={ [...code to recalculate p2]  })
plotOutput("p2")
observeEvent(input$updt, {hide("p1")})