首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >自动关闭日期范围输入闪亮

自动关闭日期范围输入闪亮
EN

Stack Overflow用户
提问于 2018-03-20 16:28:23
回答 1查看 499关注 0票数 1

我希望日期选择器在选定日期后自动关闭。我知道如何在用户界面中直接呈现daterangeinput,而不是在服务器中创建daterangeinput时。

这是我的密码。

代码语言:javascript
运行
复制
library('shiny')

js_string <- "$('#dates input').bsDatepicker({autoclose: true});"

shinyApp(
  ui = fluidPage(
    tags$head(tags$script(HTML('Shiny.addCustomMessageHandler("jsCode", function(message) { eval(message.value); });'))),
    includeScript("code.js"),
    fluidRow(
      column(4, 
             uiOutput(outputId = 'dateui'),
             verbatimTextOutput("datesOut")
      )
    )
  ), 
  server = function(input, output, session) {
    output$dateui <- renderUI({
      dateRangeInput("dates", label = h3("Date range"))
    })
    session$onFlushed(function() {
      session$sendCustomMessage(type = 'jsCode', list(value = js_string))
    })
    output$datesOut <- renderPrint({ names(session) })
  }
)

如果数据交换是直接在ui中创建的,$('#dates input').bsDatepicker({autoclose: true});工作得很好,如下面的代码所示。此外,如果我想用$('#dates').attr('onkeydown', 'return false');禁用键盘输入,这段代码也能很好地工作。

代码语言:javascript
运行
复制
library('shiny')

shinyApp(
  ui = fluidPage(
    includeScript("code.js"),
    fluidRow(
      column(4, 
             dateRangeInput("dates", label = h3("Date range")),
             verbatimTextOutput("datesOut")
      )
    )
  ), 
  server = function(input, output, session) {
    output$datesOut <- renderPrint({ input$dates })
  }
)

用js代码

代码语言:javascript
运行
复制
$(document).ready(function(){
  $('#dates input').bsDatepicker({autoclose: true});
});

我的问题与我发布的another question有关。

我也尝试过$('#dates input').datepicker({autoclose: true});,但它不起作用。我知道,$(document).ready(function() ...无法工作,因为一旦文档准备就绪,代码就会启动,因此在呈现daterange之前。

编辑:

我也尝试过使用shinyjs,但它也不起作用。

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

jsCode <- "shinyjs.changeDate = function(){
$('#dates input').bsDatepicker({autoclose: true});
$('#dates').attr('onkeydown', 'return false');
}"

shinyApp(
  ui = fluidPage(
    useShinyjs(),
    extendShinyjs(text = jsCode),
    fluidRow(
      column(4, 
             uiOutput(outputId = 'dateui'),
             verbatimTextOutput("datesOut")
      )
    )
  ),
  server = function(input, output, session) {
    output$dateui <- renderUI({
      dateRangeInput("dates", label = h3("Date range"))
    })
    session$onFlushed(function() {
      js$changeDate()
    })
  }
)

我被困在这里,任何帮助都是非常感谢的。

干杯

Edit2:添加我的会话信息

代码语言:javascript
运行
复制
R version 3.4.4 (2018-03-15)
Platform: x86_64-apple-darwin15.6.0 (64-bit)
Running under: macOS High Sierra 10.13.3

Matrix products: default
BLAS: /System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBLAS.dylib
LAPACK: /Library/Frameworks/R.framework/Versions/3.4/Resources/lib/libRlapack.dylib

locale:
[1] en_US.UTF-8/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8

attached base packages:
[1] stats     graphics  grDevices utils     datasets  methods   base     

other attached packages:
[1] shinyjs_1.0 shiny_1.0.5 V8_1.5     

loaded via a namespace (and not attached):
 [1] compiler_3.4.4  R6_2.2.2        htmltools_0.3.6 tools_3.4.4     curl_3.1       
 [6] yaml_2.1.18     Rcpp_0.12.16    digest_0.6.15   jsonlite_1.5    xtable_1.8-2   
[11] httpuv_1.3.6.2  mime_0.5 
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-03-22 00:32:30

这有点麻烦,但它使用JQuery工作:

代码语言:javascript
运行
复制
            tags$head(
                tags$script(HTML("setInterval(
                      function checkContainer () {
                        if($('.datepicker-days').is(':visible')){ //if the container is visible on the page
                          $(function () {
                              $('td.day').click(function () {
                                $('.dropdown-menu').hide()
                              }); 
                            });
                          } else {
                            setTimeout(checkContainer, 50); //wait 50 ms, then try again
                          }
                        },
                      50  /* 10000 ms = 10 sec */
                      );"))
            )

您所需要做的就是将其添加到fluidpageui的标签$head函数中。

如果最后一次用户输入是选择日期,则此操作有效。

如果您的dateRangeInput仅限于选择月份,那么您所要做的就是编辑'.datepicker-days''.datepicker-months',并将'.td.day'更改为'.td.month'。如果限制为一年,请将days更改为years,将day更改为year

其原因是,JQuery脚本每50‘s重新部署一次,以检查datepicker-days类是否为visible...but,它是否工作。

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

https://stackoverflow.com/questions/49389497

复制
相关文章

相似问题

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