在同一页面上使用多个日期范围选择器实例

3

我有两个Bootstrap日期范围选择器。当我更改一个选择器的日期时,第二个日期范围选择器中会出现相同的日期。

如何分开这两个日期范围选择器,使它们各自独立运作?

代码:

第一个日期选择器:

<div id="reportrange" class=" form-control">
<i class="glyphicon glyphicon-calendar fa fa-calendar"></i>&nbsp;
<b class="caret "></b>&nbsp;<span></span> 
</div>

第二个日期选择器:

<div id="usersdaterange" class=" form-control"> <i class="glyphicon 
glyphicon-calendar fa fa-calendar"></i>&nbsp;<b class="caret "></b>&nbsp;
<span></span>
</div>

JS:

$('#usersdaterange 
span ').on('
  apply.daterangepicker ',function(ev1,picker1) {
  var username1 = $("#userfilter").val();
  var start1 = picker1.startDate.format('YYYY-MM-DD');
  var end1 = picker1.endDate.format('YYYY-MM-DD');
});

$('#reportrange span').on('apply.daterangepicker', function(ev, picker) {
  $("#loader").show();
  var username = $("#userfilter").val();
  var start = picker.startDate.format('YYYY-MM-DD');
  var end = picker.endDate.format('YYYY-MM-DD');
});

你的 JavaScript 代码有错误。 - Alvarez
@LuisFernando,感谢您的回复。您想要识别那些错误吗? - moazzam
首先,您没有关闭关于on()的括号。从那个开始... - Snowmonkey
哦,是的,但是同样的问题。 - moazzam
2
请提供完整的代码,尝试再现它将很困难。 - Alvarez
1个回答

0

Bootstrap日期范围选择器可以直接处理多个实例。

$(function() {
  $('#dateRange1').daterangepicker({}, onSelect);
  $('#dateRange2').daterangepicker({opens:"left"}, onSelect);
});


function onSelect(start, end, label) {
    console.log("A new date selection was made: " + start.format('YYYY-MM-DD') + ' to ' + end.format('YYYY-MM-DD'));
  }
body{
  padding:20px;
}

#dateRange1.form-control,
#dateRange2.form-control{
  width:45vw;
}

#dateRange1{
  position:absolute;
  left:10px;
}

#dateRange2{
  position:absolute;
  right:10px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.jsdelivr.net/momentjs/latest/moment.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/daterangepicker/daterangepicker.min.js"></script>
<link href="https://cdn.jsdelivr.net/npm/daterangepicker/daterangepicker.css" rel="stylesheet"/>
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet"/>

<input id="dateRange1" class="form-control" type="text" name="daterange" value="01/01/2018 - 01/15/2018" />

<input id="dateRange2" class="form-control" type="text" name="daterange" value="01/01/2018 - 01/15/2018" />

(JSFiddle)

如果这两个日期选择器是联动的,那么肯定是因为有一些代码在同时更新它们。最明显的可能性是,在apply.daterangepicker上调用了某个函数,然后使用setStartDatesetEndDate等函数来更新另一个日期选择器。

(不幸的是,从他们发布的代码中无法清楚地了解原始提问者的问题,但我认为我应该回答这个问题,以消除任何潜在的混淆,供任何搜索此类问题的人参考)


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接