我正在尝试确定shiny
DataTable
是否可以为某些行禁用行选择。
使用selection
的{{1}}参数我可以预先选择行,确定用户是选择行还是列,还是两者都选择,并完全禁用选择,但是我不清楚可以指示要排除的特定行。这可能吗?
此致
答案 0 :(得分:1)
使用Select
扩展名,您可以执行以下操作:
library(DT)
library(shiny)
dat <- iris[1:17,]
rowCallback <- c(
"function(row, data, displayNum, displayIndex){",
" var indices = [0, 2, 4, 15];",
" if(indices.indexOf(displayIndex) > -1){",
" $(row).find('td').addClass('notselectable');",
" }",
"}"
)
shinyApp(
ui = fluidPage(
DTOutput("table")
),
server = function(input, output, session) {
output[["table"]] <- renderDT({
dat %>%
datatable(options = list(
rowCallback = JS(rowCallback),
select = list(style = "multi", selector = "td:not(.notselectable)")
),
extensions = "Select", selection = "none"
)
}, server = FALSE)
}
)
但是,如果您需要input$table_rows_selected
中选定行的索引,则必须为此使用JavaScript进行编码:
callback <- c(
"var id = $(table.table().node()).closest('.datatables').attr('id');",
"table.on('click', 'tbody', function(){",
" setTimeout(function(){",
" var indexes = table.rows({selected:true}).indexes();",
" var indices = Array(indexes.length);",
" for(var i = 0; i < indices.length; ++i){",
" indices[i] = indexes[i];",
" }",
" Shiny.setInputValue(id + '_rows_selected', indices);",
" }, 0);",
"});"
)
shinyApp(
ui = fluidPage(
DTOutput("table")
),
server = function(input, output, session) {
output[["table"]] <- renderDT({
dat %>%
datatable(
callback = JS(callback),
options = list(
rowCallback = JS(rowCallback),
select = list(style = "multi", selector = "td:not(.notselectable)")
),
extensions = "Select", selection = "none"
)
}, server = FALSE)
observe({
print(input[["table_rows_selected"]])
})
}
)