仅在单击菜单项时加载闪亮模块
Loading shiny module only when menu items is clicked
背景
在模块化1 Shiny 应用程序中,我只想在单击 shinydashboard 上的菜单项时加载模块。如果未访问菜单项,我不想加载该模块。
基本应用
app.R
# Libs
library(shiny)
library(shinydashboard)
# Source module
source("sample_module.R")
ui <- dashboardPage(
dashboardHeader(title = "Dynamic sidebar"),
dashboardSidebar(sidebarMenuOutput("menu")),
dashboardBody(tabItems(
tabItem(tabName = "tab_one", h1("Tab One")),
tabItem(tabName = "tab_two", sampleModuleUI("sampleModule"))
))
)
server <- function(input, output) {
callModule(sampleModuleServer, "sampleModule")
output$menu <- renderMenu({
sidebarMenu(
menuItem(
"Menu item 1",
icon = icon("calendar"),
tabName = "tab_one"
),
menuItem(
"Menu item 2",
icon = icon("globe"),
tabName = "tab_two"
)
)
})
}
shinyApp(ui, server)
sample_module.R
sampleModuleServer <- function(input, output, session) {
output$plot1 <- renderPlot({
plot(mtcars)
})
}
sampleModuleUI <- function(id) {
ns <- NS(id)
plotOutput(ns("plot1"))
}
期望的实施
仅当单击相关菜单项时,所需的实施才会加载 sample_module
。在 2:
行
不要从 observeEvent 内部调用 callModule;保持在最高水平。获取返回的响应式表达式,并使用 eventReactive 将其包装在按钮单击中。并使用输出中的 eventReactive 等
x <- callModule(...)
y <- eventReactive(input$go, x())
output$tbl <- DT::renderDataTable(y())
尝试
app.R
(修改)
# Libs
library(shiny)
library(shinydashboard)
# Source module
source("sample_module.R")
ui <- dashboardPage(
dashboardHeader(title = "Dynamic sidebar"),
dashboardSidebar(sidebarMenuOutput("menu")),
dashboardBody(tabItems(
tabItem(tabName = "tab_one", h1("Tab One")),
tabItem(tabName = "tab_two", sampleModuleUI("sampleModule"))
))
)
server <- function(input, output) {
eventReactive(eventExpr = input$tab_two,
valueExpr = callModule(sampleModuleServer, "sampleModule")
)
output$menu <- renderMenu({
sidebarMenu(
menuItem(
"Menu item 1",
icon = icon("calendar"),
tabName = "tab_one"
),
menuItem(
"Menu item 2",
icon = icon("globe"),
tabName = "tab_two"
)
)
})
}
shinyApp(ui, server)
问题
应用程序运行但模块未加载。问题:
- 如何在仪表板菜单项上正确调用
eventReactive
? tab_item
似乎没有 id
参数在该上下文中是否等同于 tabName
?
- 链接的讨论是指刷新一个table。我试图找出将与包含大量界面元素和精心设计的服务器调用的模块一起使用的示例。
单击菜单项 2 应显示 sample_module.R
文件中的内容。
2 Google groups: activate module with actionButton
更新
我尝试使用以下语法明确强制模块进入应用程序环境加载:
eventReactive(eventExpr = input$tab_two,
valueExpr = callModule(sampleModuleServer, "sampleModule"),
domain = MainAppDomain
)
哪里
MainAppDomain <- getDefaultReactiveDomain()
编辑:删除 Joe Cheng 的顶级声明:
# Libs
library(shiny)
library(shinydashboard)
# Source module
source("sample_module.R")
ui <- dashboardPage(
dashboardHeader(title = "Dynamic sidebar"),
dashboardSidebar(sidebarMenuOutput("menu")),
dashboardBody(tabItems(
tabItem(tabName = "tab_one", h1("Tab One")),
tabItem(tabName = "tab_two", sampleModuleUI("sampleModule"))
))
)
server <- function(input, output) {
observeEvent(input$tabs,{
if(input$tabs=="tab_two"){
callModule(sampleModuleServer, "sampleModule")
}
}, ignoreNULL = TRUE, ignoreInit = TRUE)
output$menu <- renderMenu({
sidebarMenu(id = "tabs",
menuItem(
"Menu item 1",
icon = icon("calendar"),
tabName = "tab_one"
),
menuItem(
"Menu item 2",
icon = icon("globe"),
tabName = "tab_two"
)
)
})
}
shinyApp(ui, server)
此外,您的 sidebarMenu
需要一个 ID 才能访问所选的标签;请查看 shinydashboard documentation.
背景
在模块化1 Shiny 应用程序中,我只想在单击 shinydashboard 上的菜单项时加载模块。如果未访问菜单项,我不想加载该模块。
基本应用
app.R
# Libs
library(shiny)
library(shinydashboard)
# Source module
source("sample_module.R")
ui <- dashboardPage(
dashboardHeader(title = "Dynamic sidebar"),
dashboardSidebar(sidebarMenuOutput("menu")),
dashboardBody(tabItems(
tabItem(tabName = "tab_one", h1("Tab One")),
tabItem(tabName = "tab_two", sampleModuleUI("sampleModule"))
))
)
server <- function(input, output) {
callModule(sampleModuleServer, "sampleModule")
output$menu <- renderMenu({
sidebarMenu(
menuItem(
"Menu item 1",
icon = icon("calendar"),
tabName = "tab_one"
),
menuItem(
"Menu item 2",
icon = icon("globe"),
tabName = "tab_two"
)
)
})
}
shinyApp(ui, server)
sample_module.R
sampleModuleServer <- function(input, output, session) {
output$plot1 <- renderPlot({
plot(mtcars)
})
}
sampleModuleUI <- function(id) {
ns <- NS(id)
plotOutput(ns("plot1"))
}
期望的实施
仅当单击相关菜单项时,所需的实施才会加载 sample_module
。在 2:
不要从 observeEvent 内部调用 callModule;保持在最高水平。获取返回的响应式表达式,并使用 eventReactive 将其包装在按钮单击中。并使用输出中的 eventReactive 等
x <- callModule(...) y <- eventReactive(input$go, x()) output$tbl <- DT::renderDataTable(y())
尝试
app.R
(修改)
# Libs
library(shiny)
library(shinydashboard)
# Source module
source("sample_module.R")
ui <- dashboardPage(
dashboardHeader(title = "Dynamic sidebar"),
dashboardSidebar(sidebarMenuOutput("menu")),
dashboardBody(tabItems(
tabItem(tabName = "tab_one", h1("Tab One")),
tabItem(tabName = "tab_two", sampleModuleUI("sampleModule"))
))
)
server <- function(input, output) {
eventReactive(eventExpr = input$tab_two,
valueExpr = callModule(sampleModuleServer, "sampleModule")
)
output$menu <- renderMenu({
sidebarMenu(
menuItem(
"Menu item 1",
icon = icon("calendar"),
tabName = "tab_one"
),
menuItem(
"Menu item 2",
icon = icon("globe"),
tabName = "tab_two"
)
)
})
}
shinyApp(ui, server)
问题
应用程序运行但模块未加载。问题:
- 如何在仪表板菜单项上正确调用
eventReactive
?tab_item
似乎没有id
参数在该上下文中是否等同于tabName
? - 链接的讨论是指刷新一个table。我试图找出将与包含大量界面元素和精心设计的服务器调用的模块一起使用的示例。
单击菜单项 2 应显示 sample_module.R
文件中的内容。
2 Google groups: activate module with actionButton
更新
我尝试使用以下语法明确强制模块进入应用程序环境加载:
eventReactive(eventExpr = input$tab_two,
valueExpr = callModule(sampleModuleServer, "sampleModule"),
domain = MainAppDomain
)
哪里
MainAppDomain <- getDefaultReactiveDomain()
编辑:删除 Joe Cheng 的顶级声明:
# Libs
library(shiny)
library(shinydashboard)
# Source module
source("sample_module.R")
ui <- dashboardPage(
dashboardHeader(title = "Dynamic sidebar"),
dashboardSidebar(sidebarMenuOutput("menu")),
dashboardBody(tabItems(
tabItem(tabName = "tab_one", h1("Tab One")),
tabItem(tabName = "tab_two", sampleModuleUI("sampleModule"))
))
)
server <- function(input, output) {
observeEvent(input$tabs,{
if(input$tabs=="tab_two"){
callModule(sampleModuleServer, "sampleModule")
}
}, ignoreNULL = TRUE, ignoreInit = TRUE)
output$menu <- renderMenu({
sidebarMenu(id = "tabs",
menuItem(
"Menu item 1",
icon = icon("calendar"),
tabName = "tab_one"
),
menuItem(
"Menu item 2",
icon = icon("globe"),
tabName = "tab_two"
)
)
})
}
shinyApp(ui, server)
此外,您的 sidebarMenu
需要一个 ID 才能访问所选的标签;请查看 shinydashboard documentation.