是否可以在闪亮的DT数据表中选择最多一定数量的单元格?我说的是单元格而不是行。
library(shiny)
if (packageVersion('DT') < '0.1.3') devtools::install_github('rstudio/DT')
library(DT)
shinyApp(
ui = fluidPage(
fluidRow(
h1('Client-side processing'),
DT::dataTableOutput('x1')
)
),
server = function(input, output, session) {
output$x1 = DT::renderDataTable(
iris, server = FALSE,
selection = list(mode = 'multiple',target="cell")
)
}
)
答案 0 :(得分:1)
是的,借助Select扩展名:
library(shiny)
library(DT)
callback <- c(
"var tblID = $(table.table().node()).closest('.datatables').attr('id');",
"var inputName = tblID + '_cells_selected:DT.cellInfo'",
"",
"table.on('select', function(e, dt, type, ix){",
" var selected = dt.cells({selected: true});",
## send selected cells to Shiny
" var indices = selected.indexes().toArray()",
" .map(function(x){return {row: x.row+1, column: x.column};});",
" Shiny.setInputValue(inputName, indices);",
## deselect if more than 5 selected
" if(selected.count() > 5){",
" dt.cells(ix).deselect();",
" }",
"});",
"",
# on deselect, also send selected cells to Shiny
"table.on('deselect', function(e, dt, type, ix){",
" var selected = dt.cells({selected: true});",
" var indices = selected.indexes().toArray()",
" .map(function(x){return {row: x.row+1, column: x.column};});",
" Shiny.setInputValue(inputName, indices);",
"});"
)
ui <- fluidPage(
br(),
DTOutput("tbl"),
br(),
h3("Selected cells:"),
verbatimTextOutput("selectedCells")
)
server <- function(input, output, session){
output[["tbl"]] <- renderDT({
datatable(
iris[1:6,],
selection = "none",
extensions = "Select",
callback = JS(callback),
options = list(
select = list(style = "multi", items = "cell")
)
)
})
output[["selectedCells"]] <- renderPrint({
input[["tbl_cells_selected"]]
})
}
shinyApp(ui, server)