1

この質問が以前に尋ねられたことは知っていますが、私がやろうとしていることに近いものを見つけることができませんでした. jQuery Datepicker http://keith-wood.name/datepick.htmlを使用しており、2 つのカレンダーで範囲を使用しています。私のアプリには、1 日分の料金を請求するサービスがあります。私がやりたいことは、エンド ユーザーに日付範囲を提供して、購入したい日数を選択し、合計を表示することです。始めに、範囲で選択された日数を計算する方法を知りたいだけです。

これが私のコードです:

<?php 
// this has the css and javascript includes
include('includes/header.php');
?>
<div class="container">
<div class="row">
<div class="span3"></div>
<div class="span9">
    <form>
  <div class="controls">
    <input id="range2Picker" name="range2Picker" value=""  class="input-large" required="" type="text"> 
  </div>
</form>
</div>
</div>

</div>

<script>
$('#range2Picker').datepick({ 
    date1 = new Date(date1);
    date2 = new Date(date2);
    rangeSelect: true, 
    monthsToShow: 2,
    changeMonth: false,
    minDate: +3,
    onClose: function(date1, date2) { 
        var timediff = date2 - date1;
        alert('Number of days are: ' + timediff); 
    } 

});

</script>
4

2 に答える 2

1

Math.ceilサマータイム時間(夏時間)前後の問題の餌食になることを含む答え。たとえば、米国では次のようになります。

Math.ceil((new Date("November 4, 2013").getTime() - 
           new Date("November 2, 2013").getTime()) / (1000 * 3600 * 24)); //=> 3

Math.floor春にも同じ問題が発生します。

Math.floor((new Date("March 11, 2013").getTime() - 
            new Date("March 9, 2013").getTime()) / (1000 * 3600 * 24)); // 1

Math.round の方が良いでしょう:

var days = Math.round( (1*date2 - 1*date1) / 86400000, 0);
于 2013-08-21T00:48:03.807 に答える
0

it gives you difference in millis, convert them into days

var timeDiff = Math.abs(date2.getTime() - date1.getTime());
var diffDays = Math.ceil(timeDiff / (1000 * 3600 * 24)); 
alert(diffDays)​;
于 2013-08-21T00:36:03.637 に答える