r - 如何将反应性rhandsontable重置为默认值?
问题描述
我正在构建一个应用程序,其中 2×2 表包含一些用于进一步计算的值。这些值可以由用户更新,并且用户将能够恢复到原始值。
我正在尝试使用将表格重置为其原始值的操作按钮来实现它,但表格不会更新。这是一个简化的例子:
rm(list = ls())
library(shiny)
library(rhandsontable)
library(shinyjs)
server <- shinyServer(function(input, output, session) {
DF = data.frame(A = c(1, 2), B = c(3, 4), row.names = c("C", "D"))
vals <- reactiveValues(reset = FALSE)
## Initiate table
previous <- reactive({DF})
myChanges <- reactive({
if(is.null(input$two_by_two)) {
return(previous())
} else if(!identical(previous(),
input$two_by_two)){
mytable <- as.data.frame(hot_to_r(input$two_by_two))
mytable
}
})
output$two_by_two <- renderRHandsontable({
if(isolate(vals$reset) | is.null(input$two_by_two)) {
isolate(vals$reset <- FALSE)
df <- DF
} else df <- myChanges()
rhandsontable(df)
})
fctout = reactive({2*myChanges()})
output$chg_data = renderTable({fctout()}, rownames = TRUE)
observeEvent(input$reset_input, {
shinyjs::reset("test")
vals$reset <- TRUE
})
})
############ UI
ui <- shinyUI(fluidPage(
shinyjs::useShinyjs(),
id = "test",
h4("A table:"),
actionButton(inputId = "reset_input",
label = "Use example"),
br(),
rHandsontableOutput("two_by_two"),
br(),
tableOutput(outputId = "chg_data")
))
shinyApp(ui, server)
是否rhandsontable
可以通过 响应和更新actionButton
?
解决方案
欢迎来到 Stackoverflow!
这是一个工作示例(降低了复杂性):
library(shiny)
library(rhandsontable)
server <- shinyServer(function(input, output, session) {
DF <- data.frame(A = c(1, 2), B = c(3, 4), row.names = c("C", "D"))
output$two_by_two <- renderRHandsontable({
input$reset_input # trigger rendering on reset
rhandsontable(DF)
})
output$chg_data = renderTable({
hot_to_r(req({input$two_by_two}))*2}, rownames = TRUE)
})
ui <- shinyUI(fluidPage(
h4("A table:"),
actionButton(inputId = "reset_input", label = "Reset"),
br(),
rHandsontableOutput("two_by_two"),
br(),
tableOutput(outputId = "chg_data")
))
shinyApp(ui, server)
推荐阅读
- javascript - 使用 javascript/vue 的产品过滤器排序最高或最低
- php - spatie/laravel-translatable 5.6 无法翻译 slug 并抛出 404
- accelerated-mobile-page - 将用户同意传递给 amp 页面中的嵌套 iframe
- javascript - if else 语句 jquery(附加到不同的选项卡)
- java - 为什么我的程序无法检测到超过 90 的分贝?
- ubuntu - ubuntu 18.04 中的 Wacom ONE 数位板驱动程序
- angular - '"
" is not a constructor' and Cannot read property 'find' of undefined errors with mongoose - java - How to Build Application on Different Environments for java jersey maven project
- jsf - PrimeFaces Extensions pe:sheet 组件实时滚动
- python - 无法在通讯录交换中创建笔记