如何以闪亮的百分比显示“numericInput”中的值?

Chr*_*ian 10 r shiny

我创建了一个闪亮的网页,在侧边栏面板中我使用了几个数字输入字段。其中一些应该以百分比形式显示值,而不应该是滑块。有人知道如何格式化数字输入字段吗?

Jan*_*Jan 2

我可以想到两种方法来做到这一点。

1. 格式化内容

使用文本字段并解析服务器代码中的内容。此时该解决方案只能处理整数。基本上,它有效。然而,与之交互并不总是能给您带来最好的可用性。

ui <- fluidPage(
    titlePanel("Parsed Input with Unit Example"),
    textInput("inpPercent", "Chances of Success", value = "20 %"),
    h1(textOutput("txtSuccess"))
)
server <- function(session, input, output) {
  observeEvent( input$inpPercent,{
    Format <- "^[-+]?[ ]*[0-9]*[ ]*[%]?$"

    # Trim
    inp <- gsub("^\\s+|\\s+$", "", input$inpPercent)
    
    if (!grepl(Format, inp)) {
      Result <- "Invalid format"
      inp <- numeric()
    } else {
      # Remove all spaces
      inp <- gsub("[[:space:]]", "", inp)
      # Split
      if (grepl("%", inp)) inp <- gsub("%", "", inp)
      inp <- suppressWarnings( as.numeric(inp) )
      if (is.na(inp)) {
        Result <- "Invalid format2"
        inp <- numeric()
      } else {
        Result <- paste("Percent:", inp)
      }
    }
  
    print(Result)
    output$txtSuccess <- renderPrint(Result)
    if (length(inp) > 0)
      updateTextInput(session, inputId = "inpPercent", value = paste(inp, "%"))
  })
}
Run Code Online (Sandbox Code Playgroud)

2.闪亮的小部件:numericInputIcon

使用shinyWigdets包中的小部件numericInputIcon。设置这样的小部件非常容易。该文档还提供了百分比示例。

numericInputIcon 小部件的示例