Я думал, что у меня есть решение, но теперь я боюсь, что неправильно понял ваш вопрос.С помощью приведенного ниже кода значения в столбце value
обновляются в соответствии со статусом соответствующего флажка в столбце value_check
.
js <- c(
"$('[id^=check]').on('click', function(){",
" var id = this.getAttribute('id');",
" var i = parseInt(/check(\\d+)/.exec(id)[1]);",
" var value = $(this).prop('checked');",
" var cell = table.cell(i-1, 2).data(value).draw();",
"})"
)
, затем
output$tbl <- renderDT(server = FALSE, escape = FALSE, editable = TRUE,
callback = JS(js),
options = list(
dom = 't', paging = FALSE, ordering = FALSE,
preDrawCallback = JS('function() { Shiny.unbindAll(this.api().table().node()); }'),
drawCallback = JS('function() { Shiny.bindAll(this.api().table().node()); } ')
), {
df$value_check <- shinyInput(checkboxInput, nrow(df), "check")
df
}
)
![enter image description here](https://i.stack.imgur.com/gX1yW.gif)
Но теперь я понимаю, что вы спрашиваете «обратное»: установите флажок в соответствии со значением в столбце value
.Правильно ?Но разве вам не нужно и вышесказанное?
Тогда, чтобы ответить на ваш вопрос в том виде, в каком я его понимаю сейчас, я бы сделал:
shinyCheckboxes <- function(len, id, checked){
inputs <- character(len)
for (i in seq_len(len)) {
inputs[i] <- as.character(checkboxInput(paste0(id, i), label=NULL,
value = checked[i]))
}
inputs
}
затем
checked <- sapply(df$value, isTRUE)
df$value_check <- shinyCheckboxes(nrow(df), "check", checked)
Это то, что вы хотите?