我想在用户点击某些文本时使用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弹出窗口。
答案 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();
}
}
);
});