Webapplicaties bouwen met Shiny in R
Ramnath Vaidyanathan
VP of Product Research

Gebruikersinvoer via de browserinterface, meestal
ui <- fluidPage( titlePanel('Greeting'),textInput('name', 'Enter Name')) server <- function(input, output, session){ } shinyApp(ui = ui, server = server)
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) })}
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)
})
}
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