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)
如果您想要在框标题的右上角有一个按钮,您可以修改原始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)
| 归档时间: |
|
| 查看次数: |
2804 次 |
| 最近记录: |