javascript - 手动 Shiny 扩展子菜单项

标签 javascript r shiny shinydashboard shinyjs

我正在尝试手动展开 Shiny 仪表板侧边栏中的子菜单。 updateTabItems 函数允许我转到选项卡,但它不会用它展开菜单。

我正在寻找该问题的可重复答案:how to manually expand a submenu in a shiny dashboard side bar 其中包括一个很好的工作示例和答案,但尚未实现。

最佳答案

这是基于 referred answer 的工作代码。请注意,在这种情况下,JavaScript 使用 tabName 作为选择器将 active 类添加到树形菜单。

library(shiny)
library(shinydashboard)
library(shinyjs)

ui <- dashboardPage(
  dashboardHeader(title = "Simple tabs"),
  dashboardSidebar(
    sidebarMenu(
      id = "tabs",
      actionButton('switchtab', 'Switch tab'),
      menuItem("Widgets", tabName = "widgets", icon = icon("th")),
      menuItem("Dashboard", tabName = "dashboard", icon = icon("dashboard"),
               menuSubItem("Sub Menu 1",icon = icon("folder-open"), tabName = "subMenu1")
      )
    )
  ),
  dashboardBody(
    useShinyjs(), 
    extendShinyjs(text = "shinyjs.activateTab = function(name){
                  setTimeout(function(){
                  $('a[href$=' + '\"#shiny-tab-' + name + '\"' + ']').closest('li').addClass('active')
                  }, 200);
                  }"
    ),
    tabItems(
      tabItem(tabName = "subMenu1",
              h2("Dashboard tab / Sub menu 1 content")
      ),
      tabItem(tabName = "widgets",
              h2("Widgets tab content")
      )
    )
  )
  )

server <- function(input, output, session) {
  observeEvent(input$switchtab, {
    newtab <- switch(input$tabs,
                     "subMenu1" = "widgets",
                     "widgets" = "subMenu1"
    )
    updateTabItems(session, "tabs", newtab)
    if (newtab == "subMenu1")
      js$activateTab("dashboard")
  })
}

shinyApp(ui, server)

关于javascript - 手动 Shiny 扩展子菜单项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40847838/

相关文章:

r - 需要 ui.R 以字符串形式获取输入文件/目录的路径

javascript - 如何对 AES 加密缓冲区进行 Base64 编码

JavaScript继承问题

r - 动态创建UI

c++ - 分配矩阵列标准偏差的 vector 正在改变其值(RcppArmadillo)

javascript - 仅当使用 LayersControl 缩放级别 > 8 时,才在 Shiny 中显示传单 map 中的图层?

r - 根据 slider 输入选择要在数据表中显示的行数

带有非拉丁字符的 Javascript slug 函数

javascript - 如何在模态中追加一行?

linux - 如何让 R 读取我的环境变量?