【问题标题】:Function triggering before I select a date in datepicker在日期选择器中选择日期之前触发功能
【发布时间】:2023-03-09 14:18:01
【问题描述】:

我需要专家的帮助。

当我调用函数 v9_insert_cmets('1') 时,警报(sdate) 在我什至在日期选择器中选择日期之前触发。

我的目标是让 v9_insert_cmets() 检查 sdate 是否为空。如果它为 null 则只需 { return } 如果不是 { do something else }。

当前情况,如果该 sdate 始终为 null,因为 datepicker 永远没有机会设置它。

var sdate

//========================================================================
  function v9_insert_comments(x) {
//========================================================================

    if (x == 1) {
            select_date()
            alert(sdate)
    }


}//end of function


//========================================================================
  function select_date() {
//========================================================================
    $('#dd').dialog({
        autoOpen: true,
        modal: true,
        overlay: {
            opacity: 0.5,
            background: 'black'
        },
        title: "title",
        height: 265,
        width: 235,
        draggable: false,
        resizable: false

    }); //end of dialog

    $('#d1').datepicker({
        onSelect: function() {
            sdate = $(this).val();
            $("#dd").dialog("close");

        }
    });

} //end of function

主体:

<!-- START OF DATE SELECTOR DIALOG -->
<div style="display:none" id="dd">
<div id="d1"></div>
</div>
<!-- END OF DATE SELECTOR DIALOG -->

【问题讨论】:

    标签: javascript jquery jquery-ui javascript-framework


    【解决方案1】:

    在您的select_date 方法中,您只是在进行设置。对$('#dd').dialog() 的调用执行了所有jQuery UI 魔术来创建一个对话框,通过更新DOM 并将其连接起来。然后你调用$('#d1').datepicker(),它以类似的方式设置一个日期选择器。它只是说“这个 div 现在是一个对话框,这个 div 现在是一个日期选择器”。它不等待任何用户交互。您的 v9_insert_comments 函数假设事情是同步发生的,而它们实际上是异步发生的。

    这些东西都设置好后,你马上要一个还没有设置的变量的值。它尚未设置,因为您为日期选择器的 onSelect 事件提供的匿名函数尚未触发。只有在日期选择器中选择了某些内容时才会调用此函数。因此,如果您想对选定的日期执行某些操作,请在事件处理程序中执行。

    您可以将警报移动到事件处理程序,或者您可以从事件处理程序调用v9_insert_comments - 但在这种情况下,您应该将调用移动到其他地方的select_date。对话框和日期选择器只需要设置一次。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-07-28
      • 1970-01-01
      • 1970-01-01
      • 2014-03-23
      • 2014-05-21
      • 2017-02-25
      相关资源
      最近更新 更多