将jQuery datepicker分配给div元素并获取值

时间:2017-11-16 09:36:08

标签: javascript jquery html datepicker jquery-ui-datepicker

我想在用户点击某些文本时使用jQuery显示一个日期选择器,并且在用户选择datepicker上的日期之后,我可以将日期选择器中的值作为javascript变量获取。我的代码是这样的:

<div id="datepicker-container" style="display: none;">
    <div id="select-delivery-date-input"> </div>
</div>
<a id="show-datepicker">Select Delivery Date</a>
<script>
  $("#show-datepicker").click(function(){
      $("#datepicker-container").show();
  });
  $('#select-delivery-date-input').datepicker({ 
      dateFormat:'yy-m-d',
      minDate: new Date(),
  });
</script>

问题是当datepicker弹出时,当我试图在datepicker popup上选择日期时,它不会关闭datepicker弹出窗口。

Fiddle example

2 个答案:

答案 0 :(得分:1)

您可以使用datepicker的onSelect选项:

  

选择日期选择器时调用。该函数将选定日期作为文本,将datepicker实例作为参数接收。

然后你可以使用jQuery hide()

这是一个实时样本:

$(document).ready(function() {
  $("#show-datepicker").click(function(){ 
    $("#datepicker-container").show();
  });
  $('#select-delivery-date-input').datepicker({ 
    dateFormat:'yy-m-d',
    minDate: new Date(),
    onSelect: function(selectedDate){
      console.log(selectedDate);
      $("#datepicker-container").hide();
    }
  });
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.4/jquery-ui.js"></script>
<link href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.4/themes/smoothness/jquery-ui.css" rel="stylesheet"/>

<div id="datepicker-container" style="display: none;">
  <div id="select-delivery-date-input"> </div>
</div>
<a id="show-datepicker">Select Delivery Date</a>

答案 1 :(得分:0)

请在下面找到更改后的代码:

$(document).ready(function() {
var selectedDate;

  $("#show-datepicker").click(function(){ 
      $("#datepicker-container").show();
  });
  $('#select-delivery-date-input').datepicker({ 
      dateFormat:'yy-m-d',
      minDate: new Date(),
      onSelect: function(date){
      selectedDate = date;
      alert(selectedDate);//selected date is assigned to date1, you can use date1 anywhere
      $("#datepicker-container").hide();
    }
     }
   );
});