[英]Using observeEvent in shiny with null values
我正在努力解决一个反应性的 shiny 问题,并希望能得到一些帮助。 假设我有一个非常简单的应用程序,它显示给定一系列选择的平均高度:
library(tidyverse)
library(shiny)
library(DT)
df <- data.frame(cat = sample(LETTERS[1:4], 20, replace = T),
city = sample(c("Tokyo", "Madrid", "Paris"), 20, replace = T),
pop = sample(1:7, 20, replace = T),
altitude = sample(10000:15000, 20, replace = F))
ui <- fluidPage(
selectizeInput("cat", "Category:",
choices = c("A", "B", "C", "D"),
multiple = T,
selected = "A"),
selectizeInput("city","City:",
choices = NULL,
multiple = T),
selectizeInput("pop","Population:",
choices = NULL,
multiple = T),
dataTableOutput("table")
)
server <- function(input, output, session) {
observeEvent(input$cat,{
updateSelectInput(session,"city",
choices = df %>% filter(cat == input$cat) %>%
.$city %>% unique,
selected = "")
})
observeEvent(input$city,{
updateSelectInput(session,"pop",
choices = df %>% filter(cat == input$cat & city == input$city) %>%
.$pop %>% unique,
selected = "")
})
output$table <- renderDataTable({
df %>%
filter(cat == input$cat, city == input$city, pop == input$pop %>% as.numeric) %>%
summarise(mean_altitude = mean(altitude))
})
}
# Run the application
shinyApp(ui = ui, server = server)
我将如何修改此代码以允许在某些字段中选择 null 并让其他选项对此完全反应? 现在,当您从上到下的每个字段 select 时,它唯一的反应。 我希望它能够响应 null 值并且顺序无关紧要。
我可以在查询时使用复杂的情况来做到这一点,但我的实际数据集有大约 10 个不同的输入,并且通过扩展大量不同的组合,所以这样做来处理每个可能的组合是不可行的。
observeEvent(input$id, {
code
...
}, ignoreNULL = FALSE)
?observeEvent
这对我来说也是最近的发现
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.