我正在尝试确定是否可以shiny
DataTable
为某些行禁用行选择。
使用 I 的selection
参数DT::datatable
可以预先选择行,确定用户是选择行还是列或两者,并完全禁用选择,但我不清楚我是否可以指示要排除的特定行。这可能吗?
问候
我正在尝试确定是否可以shiny
DataTable
为某些行禁用行选择。
使用 I 的selection
参数DT::datatable
可以预先选择行,确定用户是选择行还是列或两者,并完全禁用选择,但我不清楚我是否可以指示要排除的特定行。这可能吗?
问候
使用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"]])
})
}
)