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');
});
4

1 回答 1

0

Bootstrap daterangepicker 适用于开箱即用的多个实例。

$(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,然后用setStartDateorsetEndDate等​​更新另一个日期选择器。

(不幸的是,从他们发布的代码中不清楚最初的提问者问题是什么,但我想无论如何我都会回答这个问题,以消除任何搜索此问题的人的潜在困惑)

于 2019-04-01T17:29:08.993 回答