有没有办法从服务器端手动禁用/启用闪亮的仪表板应用程序上的侧边栏?
如果我需要更多空间而不使用标题上的切换按钮,我想自动隐藏侧边栏。
谢谢
答案 0 :(得分:12)
我对仪表板不太熟悉,因为我从来没有构建过,但是从快速浏览看来,似乎点击打开/隐藏侧边栏按钮时,所有发生的事情都是sidebar-collapse
类得到的添加/删除到<body>
标记。也许更多的事情发生在我不知道的地方,但这似乎是最明显的事情。
因此,您可以轻松使用shinyjs包(免责声明:我是作者)来添加/删除该类
library(shiny)
library(shinydashboard)
library(shinyjs)
shinyApp(
ui =
dashboardPage(
dashboardHeader(),
dashboardSidebar(),
dashboardBody(
shinyjs::useShinyjs(),
actionButton("showSidebar", "Show sidebar"),
actionButton("hideSidebar", "Hide sidebar")
)
),
server = function(input, output, session) {
observeEvent(input$showSidebar, {
shinyjs::removeClass(selector = "body", class = "sidebar-collapse")
})
observeEvent(input$hideSidebar, {
shinyjs::addClass(selector = "body", class = "sidebar-collapse")
})
}
)