闪亮 - 仪表板页面 - 如何向框标题添加按钮

har*_*mut 2 javascript css r shiny shinydashboard

使用dashboardPage我制作了一个由盒子制成的仪表板。

我希望能够单击框标题上的某处以触发某些操作。我知道标题有按钮的唯一情况是可扩展框的情况。是否可以概括一下,以便在单击框标题中的某处时触发某些操作?

我的设计目标是在用户单击此按钮时更新框中的信息,即更改框的内容。

谢谢!

body <- dashboardBody(
  fluidRow(
    box(
      title = "Title 1", width = 4, solidHeader = TRUE, status = "primary",
      "Box content"
    ),
    box(
      title = "Title 1", width = 4, solidHeader = TRUE, status = "warning",
      "Box content"
    )
  )
)
# We'll save it in a variable `ui` so that we can preview it in the console
ui <- dashboardPage(
  dashboardHeader(title = "Row layout"),
  dashboardSidebar(),
  body
)
# Preview the UI in the console
shinyApp(ui = ui, server = function(input, output) { })
Run Code Online (Sandbox Code Playgroud)

Geo*_*any 8

如果您想要在框标题的右上角有一个按钮,您可以修改原始box函数,或者您可以使用一些 JavaScript 在创建框后添加按钮。

一个更简单的解决方案是创建一个带有actionLink或的框标题actionButton。Bellow 是这两种情况的示例。第一个框有一个actionLink标题,当用户点击它时,框的内容被更新。在第二个框中,标题是用纯文本创建的,还有一个actionButton也会更新框内容的小标题。对于第二个框,您可以添加一些自定义样式来创建与普通框大小相同的标题。

library(shiny)
library(shinydashboard)

body <- dashboardBody(
  fluidRow(
    box(
      title = actionLink("titleId", "Update", icon = icon("refresh")), 
      width = 4, solidHeader = TRUE, status = "primary",
      uiOutput("boxContentUI")
    ),
    box(
      title = p("Title 1", 
                actionButton("titleBtId", "", icon = icon("refresh"),
                  class = "btn-xs", title = "Update")
      ), 
      width = 4, solidHeader = TRUE, status = "warning",
      uiOutput("boxContentUI2")
    )
  )
)

ui <- dashboardPage(
  dashboardHeader(title = "Row layout"),
  dashboardSidebar(),
  body
)

server = function(input, output, session) { 
  output$boxContentUI <- renderUI({
    input$titleId
    pre(paste(sample(letters,10), collapse = ", "))
  }) 

  output$boxContentUI2 <- renderUI({
    input$titleBtId
    pre(paste(sample(LETTERS,10), collapse = ", "))
  })  
}

shinyApp(ui = ui, server = server)
Run Code Online (Sandbox Code Playgroud)