首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当daterangepicker()构造函数重新附加时,apply.daterangepicker事件停止触发

当daterangepicker()构造函数重新附加时,apply.daterangepicker事件停止触发
EN

Stack Overflow用户
提问于 2019-04-14 15:26:19
回答 1查看 228关注 0票数 0

我正在使用daterangepicker版本: 3.0.3

我有一个单选按钮对,允许用户在本地和utc时间之间切换。当我单击单选按钮时,我想删除并重新附加daterangepicker构造函数,这样我就可以指定不同的预定义日期范围。

但是,在单击单选按钮后,当我单击“应用”或单击预定义的日期范围时,日期选择器将停止触发事件。

我在jsfiddle上做了一个简化的程序,应用事件仍然没有触发。

https://jsfiddle.net/flexmcmurphy/re62qhb8/4/

以下是代码:

代码语言:javascript
复制
<html>
<head>
<title>Test2.html</title>
    <script src="include/jquery-3.3.1.js"></script>
    <script src="include/moment.js"></script>
    <script src="include/daterangepicker.js"></script>
    <link rel="stylesheet" type="text/css" href="include/daterangepicker.css" />
</head>
<body>
<input type="text" name="datetimes"/>
Local <input type="radio" name="timeformat" value="local" checked="checked"><span id="mybar">|</span><input type="radio" name="timeformat" value="utc"> UTC

<script>

// Global Variables
var selectedtimeformat;

// Set the selectedtimeformat variable on page load
$( document ).ready(function() {
    setSelectedTimeFormat();
    attachpicker();
});

$("input[type='radio']").click(function(){
    var radioValue = $("input[name='timeformat']:checked").val();
        if(radioValue != selectedtimeformat){
            setSelectedTimeFormat();
            if(selectedtimeformat == 'utc'){
                $('input[name="datetimes"]').data('daterangepicker').remove();
                attachpicker();
            }else{
                // Re-attach the DRP so the startDate, endDate, minDate and maxDate settings are updated for the UTC/local time choice
                $('input[name="datetimes"]').data('daterangepicker').remove();
                attachpicker();
            }
        }       
});  // end function $("input[type='radio']").click(function(){...}

function setSelectedTimeFormat(){
    selectedtimeformat = $("input[name='timeformat']:checked").val();
    alert("selectedtimeformat: " + selectedtimeformat);
}

function attachpicker(){

if(selectedtimeformat == 'local'){
    $('input[name="datetimes"]').daterangepicker({
    "opens": 'right',
    "drops": 'down',
    "timePicker": true,
    "locale": {
      "format": 'MM/DD/YYYY'
    },
    "alwaysShowCalendars": true,    
    "ranges": {
        'Today': [moment(), moment()],
        'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')],
        'Last 7 Days': [moment().subtract(6, 'days'), moment()],
        'Last 30 Days': [moment().subtract(29, 'days'), moment()],
        'This Month': [moment().startOf('month'), moment().endOf('month')],
        'Last Month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')]
    },
    "startDate": "04/08/2019",
    "endDate": "04/10/2019",
    "minDate": "04/05/2019",
    "maxDate": "04/18/2019",
    "timePickerIncrement": 10,
    "timePicker24Hour": true
    }); // <-- end of daterangepicker() constructor
}else{
// selectedtimeformat == 'utc'
    $('input[name="datetimes"]').daterangepicker({
    "opens": 'right',
    "drops": 'down',
    "timePicker": true,
    "locale": {
      "format": 'MM/DD/YYYY'
    },
    "alwaysShowCalendars": true,
    "ranges": {
        'Today': [moment(), moment()],
        'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')],
        'Last 7 Days': [moment().subtract(6, 'days'), moment()],
        'Last 30 Days': [moment().subtract(29, 'days'), moment()],
        'This Month': [moment().startOf('month'), moment().endOf('month')],
        'Last Month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')]
    },
    "startDate": "04/08/2019",
    "endDate": "04/14/2019",
    "minDate": "04/05/2019",
    "maxDate": "04/18/2019",
    "timePickerIncrement": 10,
    "timePicker24Hour": true
    }); // <-- end of daterangepicker() constructor
}

}   //<-- end of function attachpicker()

$('input[name="datetimes"]').on('apply.daterangepicker', function(ev, picker) {
    alert("apply.daterangepicker event fired");
});

</script>

</body>
</html>

预期结果:当我更改所选的单选按钮,然后选择一个预定义的日期范围,或者在数据采集器中单击"apply“,apply.daterangepicker事件应该会触发,并且会出现一个显示事件已经启动的警告()弹出。

即:应该删除daterangepicker构造函数,并重新附加新的属性。

之所以会发生这种情况,是因为当单选按钮被更改时,就会调用attachpicker()方法。

实际结果:当我更改所选的单选按钮,然后选择一个预定义的日期范围或在日期选择器中单击" apply“时,将不会弹出显示apply事件已启动的警报。

然而..。

当我更改所选的Radio时,文本框中出现的startDate和endDate将正确更新。

选择"startDate":"04/08/2019“"endDate":"04/10/2019”

startDate:"04/08/2019“"endDate":"04/14/2019”

因此,这告诉我daterangepicker构造函数确实会重新附加新的属性,只是apply事件停止触发。

为什么会这样呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-14 15:44:02

您调用的remove()函数将删除正在销毁的日期范围选择器的任何事件侦听器。

apply.daterangepicker侦听器创建移动到attachpicker()函数中。

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

https://stackoverflow.com/questions/55676937

复制
相关文章

相似问题

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