[英]R Shiny: small table with checkbox columns and a scrollbar
我正在尝试使用 golem 制作一个 Shiny 应用程序,但我对此很陌生。 这次我只想制作一个带有复选框和滚动条的小表格,但我没有成功......
到目前为止,这是我唯一设法完成的工作(但即使滚动条似乎也没有显示):
mod_saving_side_ui <- function(id){
ns <- NS(id)
tagList(
shinyjs::useShinyjs(),
shinyalert::useShinyalert(),
fluidRow(
DT::DTOutput(ns("my_marker_table"), width = "75%")
)
)
}
mod_saving_side_server <- function(id, r){
moduleServer( id, function(input, output, session){
ns <- session$ns
output$my_marker_table <- DT::renderDT({
marker_df <- data.frame(marker=LETTERS, positive="", negative="")
marker_df$positive[1] <- "y"
marker_df$negative[2:4] <- "y"
marker_matrix <- as.matrix(marker_df)
DT::datatable(marker_matrix, options = list(scrollY = TRUE, sDom = '<"top">rt<"bottom">ip'), rownames = FALSE)
})
})
}
它产生这个:
但是我想完成三件事:
Previous
1
2
3
Next
按钮positive
和negative
列有每行一个复选框A
预选positive
复选框,为 2:4 行B
、 C
、 D
预选negative
复选框如何使checkboxGroupInput
在这里工作并显示滚动条? 谢谢!
这是部分答案,只关注第 1 点。我认为您应该将这篇文章分成几篇,当我们看到要做的事情列表而不是单个问题时,这有点令人沮丧。
此外,您的示例不可重现(我们不能只是复制粘贴您的代码来制作应用程序),所以我制作了一个基本的应用程序。
基本上,我使用参数pageLength
了datatable()
底部的“1”、“2”、“3”等按钮。 只有这样做会产生一个很长的表格,所以我使用 CSS 来指定它的高度(这里我放了15em
但它是你的选择)并使其可滚动。
library(shiny)
library(DT)
ui <- fluidPage(
tags$head(
tags$style(
HTML(
"#test {
height: 15em !important;
overflow-y: scroll
}"
)
)
),
DTOutput("test")
)
server <- function(input, output, session) {
output$test <- renderDT({
datatable(iris, options = list(
pageLength = nrow(iris)
))
})
}
shinyApp(ui, server)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.