0

我需要限制用户选择单选按钮的能力,但始终显示它们。我shinyjs::disable用来禁用按钮并updateRadioButtons更新选择,但它似乎无法正常工作。只有更新似乎有效,而不是禁用我的代码:

library(shiny)
library(shinyjs)

server = shinyServer(function(input, output, session) {

observeEvent(input$toggle, {

if (input$toggle == "enable") {

  updateRadioButtons(session, "button1", "",
                     c("one" = "one", "two" = "two"),
                     inline = T, selected = "one")

  shinyjs::enable("button1")

}

if (input$toggle == "disable") {

  updateRadioButtons(session, "button1", "",
                     c("one" = "one", "two" = "two"),
                     inline = T, selected = "two")

  shinyjs::disable("button1")

}

 })

})

ui = shinyUI(

fluidPage(

shinyjs::useShinyjs(),

radioButtons("toggle", "",
           c("enable" = "enable", "disable" = "disable"), inline = T),

radioButtons("button1", "",
           c("one" = "one", "two" = "two"), inline = T)

))

shinyApp(ui=ui,server=server)
4

1 回答 1

3

发生这种情况是因为更新函数实际上是在稍后进行更新。所以发生的事情是调用了更新函数,然后调用了禁用,按钮被禁用,稍后按钮从更新中重新生成。这是因为闪亮的内部结构如何工作。如果您注释掉更新功能,您会看到该按钮确实被禁用。这有点烦人,但这只是闪亮工作方式的副作用。disable(id)您可以尝试的一种 hacky 解决方案是使用 ,代替shinyjs::delay(100, disable(id))(这意味着您将添加 100 毫秒的短暂延迟,然后才禁用)。

于 2016-08-18T07:17:32.063 回答