首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于延迟ID的shinyjs - setBookmarkExclude

用于延迟ID的shinyjs - setBookmarkExclude
EN

Stack Overflow用户
提问于 2019-04-23 17:53:56
回答 1查看 253关注 0票数 2

我试图将ShinyJS延迟排除在反应性书签上下文中。我看到URL中的延迟ID是自动生成的,并且总是不同的: delay-ad190e10123bd97f960fed7a8a9e6fde=3000。

我试图通过正则表达式排除延迟,但我不认为正则表达式正在被解析:

代码语言:javascript
复制
setBookmarkExclude(
    c("delay-[[:alnum:]]"))

我想要一种方法来设置延迟的ID,这样每次都是相同的,或者对setBookmarkExclude进行正则化以排除随机生成的延迟ID。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-24 08:24:02

请参阅以下示例:

代码语言:javascript
复制
library(shiny)
library(shinyjs)

ui <- function(request) {
    fluidPage(
        useShinyjs(),
        br(),
        bookmarkButton(id="bookmarkBtn"),
        hr(),
        textOutput("ExcludedIDsOut"),
        hr(),
        sliderInput(inputId="slider", label="My value will be bookmarked", min=0, max=10, value=5),
        textOutput("out_1"),
        textOutput("out_2"),
        textOutput("out_3")
    )
}

server <- function(input, output, session) {
    
    observeEvent(input$bookmarkBtn, {
        session$doBookmark()
    })
    
    ExcludedIDs <- reactiveVal(value = NULL)
    
    observe({
        toExclude <- "bookmarkBtn"
        
        delayExclude <- grep("delay", names(input), value = TRUE)
        if(length(delayExclude) > 0){
            toExclude <- c(toExclude, delayExclude)
        }
        
        setBookmarkExclude(toExclude)
        ExcludedIDs(toExclude)
    })
    
    output$ExcludedIDsOut <- renderText({ 
        paste("ExcludedIDs:", paste(ExcludedIDs(), collapse = ", "))
    })
    
    delay(1000, {
        output$out_1 <- renderText({ 
            "My"
        })
    })
    
    delay(2000, {
        output$out_2 <- renderText({ 
            "delayed"
        })
    })
    
    delay(3000, {
        output$out_3 <- renderText({ 
            "output"
        })
    })
}

enableBookmarking(store = "url") # store = "server"
shinyApp(ui, server)

更新:白名单方法

代码语言:javascript
复制
library(shiny)
library(shinyjs)

ui <- function(request) {
  fluidPage(
    useShinyjs(),
    br(),
    bookmarkButton(id="bookmarkBtn"),
    hr(),
    textOutput("ExcludedIDsOut"),
    hr(),
    sliderInput(inputId="slider", label="My value will be bookmarked", min=0, max=10, value=5),
    textOutput("out_1"),
    textOutput("out_2"),
    textOutput("out_3")
  )
}

server <- function(input, output, session) {
  
  bookmarkingWhitelist <- c("slider")
  
  observeEvent(input$bookmarkBtn, {
    session$doBookmark()
  })
  
  ExcludedIDs <- reactive({
    toExclude <- setdiff(names(input), bookmarkingWhitelist)
    setBookmarkExclude(toExclude)
    toExclude
  })
  
  output$ExcludedIDsOut <- renderText({ 
    paste("ExcludedIDs:", paste(ExcludedIDs(), collapse = ", "))
  })
  
  delay(1000, {
    output$out_1 <- renderText({ 
      "My"
    })
  })
  
  delay(2000, {
    output$out_2 <- renderText({ 
      "delayed"
    })
  })
  
  delay(3000, {
    output$out_3 <- renderText({ 
      "output"
    })
  })
}

enableBookmarking(store = "url") # store = "server"
shinyApp(ui, server)

这里是一个相关的GitHub问题,注意session$getBookmarkExclude()作为跟踪排除的输入的替代方法。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55816861

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档