我想在启动时渲染闪亮的图,然后要求单击操作按钮以重新渲染。我试图简化我的应用程序以在此处发布。您可以看到,更改“周”选择会触发刷新。除非单击操作,否则如何抑制所有刷新?
library(shiny); library(dplyr); library(ggplot2)
#toy data
dates= seq.Date(as.Date("2020-01-01"),as.Date("2020-05-01"),by="days")
set.seed(1)
data = data.frame(date = dates,val = runif(length(dates),50,150))
ui <- fluidPage(
sidebarLayout(
sidebarPanel(
selectInput("group","Group",choices = LETTERS[1:3]),
dateRangeInput('dateRangeCal', "Input date range"),
selectInput("week","shift week",choices = c(0:3)),
actionButton("action","Submit")
),
mainPanel(
plotOutput(outputId = "plot")
)
)
)
server <- function(input, output,session) {
observeEvent( input$action, {
startDate = as.Date("2020-01-01")+days(case_when(
input$group == "A" ~ 0,
input$group == "B" ~ 30,
input$group == "C" ~ 60
))
endDate=startDate+days(60)
updateDateRangeInput(session = session,
inputId = 'dateRangeCal',
label = 'Date range input:',
start = startDate,
end = endDate
)
},ignoreNULL = F)
output$plot <- renderPlot({
p = data %>%
filter(date>=input$dateRangeCal[1]+days(input$week)*7,date<=input$dateRangeCal[2]) %>%
ggplot(.,aes(x=date,y=val))+
geom_line()
p
})
}
shinyApp(ui, server)
应该这样做:
server <- function(input, output,session) {
week <- reactiveVal()
observeEvent( input$action, {
week(input$week)
startDate = as.Date("2020-01-01")+days(case_when(
input$group == "A" ~ 0,
input$group == "B" ~ 30,
input$group == "C" ~ 60
))
endDate=startDate+days(60)
updateDateRangeInput(session = session,
inputId = 'dateRangeCal',
label = 'Date range input:',
start = startDate,
end = endDate
)
},ignoreNULL = F)
output$plot <- renderPlot({
p = data %>%
filter(date>=input$dateRangeCal[1]+days(week())*7,date<=input$dateRangeCal[2]) %>%
ggplot(.,aes(x=date,y=val))+
geom_line()
p
})
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句