我有文本框与datepicker。根据我的要求,用户必须选择本月的第二个星期二或第二个星期二。所以我使用下面的代码禁用了其余的日期,并且它的工作正常。禁用文本框输入值
var dates_allowed = {
'2012-07-24': 1,
'2012-08-14': 1,
'2012-08-21': 1,
'2012-09-11': 1,
'2012-09-18': 1,
'2012-10-09': 1,
'2012-10-16': 1
};
$("#" + webinarDate.id).datepicker({
// called for every date before it is displayed
beforeShowDay: function(date) {
// prepend values lower than 10 with 0
function addZero(no) {
if (no < 10){
return "0" + no;
} else {
return no;
}
}
var date_str = [
addZero(date.getFullYear()),
addZero(date.getMonth() + 1),
addZero(date.getDate())
].join('-');
if (dates_allowed[date_str]) {
return [true, 'good_date', 'This date is selectable'];
} else {
return [false, 'bad_date', 'This date is NOT selectable'];
}
}
});
但问题是用户可以在文本框中输入日期而不是使用datepicker(我不希望那样)。如何限制用户从datepicker中选择日期,而不是手动输入。我希望你明白..
您必须使用日期选择器?如果唯一的选择是本月的第一个或第二个星期二,也许下拉是一个更好的选择? – 2012-07-24 15:34:05
注意:您还需要确保您有服务器端验证来检查值,而不是纯粹依靠被禁用的字段。 – Amalea 2012-07-24 15:35:33
@TheZ“disabled”文本框不会在POST上发送,因此readonly是正确的选择。 – Amalea 2012-07-24 15:36:24