Reactiviteit 101

Webapplicaties bouwen met Shiny in R

Ramnath Vaidyanathan

VP of Product Research

Een app waar de gebruiker zijn naam invoert en een persoonlijke begroeting krijgt

Webapplicaties bouwen met Shiny in R

Reactieve bron

Gebruikersinvoer via de browserinterface, meestal

ui <- fluidPage(
  titlePanel('Greeting'),

textInput('name', 'Enter Name')
) server <- function(input, output, session){ } shinyApp(ui = ui, server = server)
Webapplicaties bouwen met Shiny in R

Reactief eindpunt

Uitvoer die meestal in het browservenster verschijnt, zoals een plot of tabel

ui <- fluidPage(
  titlePanel('Greeting'),
  textInput('name', 'Enter Name'),
  textOutput('greeting')
)

server <- function(input, output, session){
output$greeting <- renderText({ paste("Hello", input$name) })
}
Webapplicaties bouwen met Shiny in R

Reactieve geleider

Een tussenlaag die afhangt van reactieve bronnen en/of reactieve eindpunten bijwerkt.

server <- function(input, output, session){
  output$plot_trendy_names <- plotly::renderPlotly({
    babynames %>% 
      filter(name == input$name) %>%
      ggplot(val_bnames, aes(x = year, y = n)) +
      geom_col() 
  })
  output$table_trendy_names <- DT::renderDT({
     babynames %>% 
      filter(name == input$name)
  })
}
Webapplicaties bouwen met Shiny in R

Reactieve expressies

Reactieve expressies zijn lui en gecachet.

server <- function(input, output, session){
  rval_babynames <- reactive({
    babynames %>% 
      filter(name == input$name)
  })
  output$plot_trendy_names <- plotly::renderPlotly({
     rval_babynames() %>%
      ggplot(val_bnames, aes(x = year, y = n)) +
      geom_col() 
  })
  output$table_trendy_names <- DT::renderDT({
     rval_babynames()
  })
}
Webapplicaties bouwen met Shiny in R

Laten we oefenen!

Webapplicaties bouwen met Shiny in R

Preparing Video For Download...