如何在闪亮的DT数据表中选择最大单元数

时间:2019-10-30 14:50:37

标签: r shiny dt

是否可以在闪亮的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")
    )

  }
)

1 个答案:

答案 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)