动态着色的sliderInput

时间:2018-01-31 16:05:52

标签: r shiny reactive-programming shinydashboard

我有一个与帖子How to color sliderbar (sliderInput)?相关的问题。

是否可以使sliderInput根据所选值更改其颜色?

我想让用户输入0到10之间的值。但是,推荐的范围是4到8.因此,如果用户选择一个值,滑块颜色应为绿色在4到8之间,如果选择了超出推荐范围的值,它应该变为橙色(或红色)。

非常感谢任何有关实施此项目的帮助。

1 个答案:

答案 0 :(得分:4)

使用renderUI,并以任何方式控制颜色()中的条件

rm(list = ls())
library(shiny)
ui <- fluidPage(

    sliderInput("slider1", "Slider 1",min = 0, max = 10, value =c(4,8), 
                 step = 1),

    uiOutput("abc")

)
server <- function(input, output, session){

    color <- reactive({
       if(input$slider1[1] < 4 || input$slider1[2] > 8 ){
         tags$style(HTML(".js-irs-0 .irs-single, .js-irs-0 .irs-bar-
               edge, .js-irs-0 .irs-bar {background: red}"))
        }else{
          tags$style(HTML(".js-irs-0 .irs-single, .js-irs-0 .irs-bar-
                  edge, .js-irs-0 .irs-bar {background: lightgreen}"))
        }
    })

  output$abc <- renderUI({ 
       color()
  })

}
shinyApp(ui = ui, server=server)