0

jQuery UI の日付ピッカーに問題があります。私はこのコードを持っています:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="http://code.jquery.com/ui/1.12.1/jquery-ui.min.js" integrity="sha256-VazP97ZCwtekAsvgPBSUwPFKdrwD3unUfSGVYrahUqU=" crossorigin="anonymous"></script>
<script>
  jQuery(document).ready(function($) {
    $('#datepickerFrom').datepicker({
      dateFormat: 'yy-m-d',
      inline: true,
      onSelect: function(dateText, inst) {
        var date = $(this).datepicker('getDate'),
          day = date.getDate(),
          month = date.getMonth() + 1,
          year = date.getFullYear();

        var url = $('#reservation').attr('href');
        url = url.replace('05&', day + '&');
        $('#reservation').attr('href', url);

        var url2 = $('#reservation').attr('href');
        url2 = url2.replace('12', month);
        $('#reservation').attr('href', url2);

        var url3 = $('#reservation').attr('href');
        url3 = url3.replace('2016', year);
        $('#reservation').attr('href', url3);
      }
    });

    $('#datepickerTo').datepicker({
      dateFormat: 'yy-m-d',
      inline: true,
      onSelect: function(dateText, inst) {
        var date = $(this).datepicker('getDate'),
          day = date.getDate(),
          month = date.getMonth() + 1,
          year = date.getFullYear();

        var url4 = $('#reservation').attr('href');
        url4 = url4.replace('=2016', '=' + year);
        $('#reservation').attr('href', url4);

        var url5 = $('#reservation').attr('href');
        url5 = url5.replace('13', +month);
        $('#reservation').attr('href', url5);

        var url6 = $('#reservation').attr('href');
        url6 = url6.replace('09', day);
        $('#reservation').attr('href', url6);

      }
    });
  });
</script>
<p>Date arrivée :
  <input type="text" id="datepickerFrom">
</p>
<p>Date départ :
  <input type="text" id="datepickerTo">
</p>

<a id="reservation" class="et_pb_button  et_pb_button_0 et_pb_module et_pb_bg_layout_light" href="https://mywebsite.com/book?shs&chkin=2016-12-05&chkout=2016-13-09&step=1">Réservez</a>

日付 (datepickerTo と datepickerFrom) をクリックすると、href リンクが 1 回だけ更新されます。日付を変更すると、スクリプトが実行されません。

4

1 に答える 1

1

初期値を検索して置換するため、最初にのみ機能します。あなたのこのコードをチェックしてください:

var url = $('#reservation').attr('href');
url = url.replace('05&', day + '&');
$('#reservation').attr('href', url);
var url2 = $('#reservation').attr('href');
url2 = url2.replace('12', month);
$('#reservation').attr('href', url2);
var url3 = $('#reservation').attr('href');
url3 = url3.replace('2016', year);
$('#reservation').attr('href', url3);

基本的に、「05」は指定された日、「12」は指定された月、「2016」は指定された年に置き換えられます。ユーザーが別の日付を選択すると、このコードはこの新しい日付に置き換えるものを何も見つけません。

于 2016-12-07T13:33:37.293 に答える