我需要将最大日期限制在今天的日期之前,所以我使用下一个代码:
<div class="datepicker">
@Html.TextBoxFor(m => m.Birthdate, "{0:dd.MM.yyyy}", new { @class = "form-control", @style="max-width: 240px;" })
</div>
<script type="text/javascript">
$(function () {
$('.datepicker input').datepicker({
language: "ru",
autoclose: true,
format: "dd.mm.yyyy",
todayHighlight: true,
maxDate: new Date()
});
});
</script>
由于不同浏览器之间存在一些问题,我还使用了自定义日期验证器:
jQuery.validator.methods.date = function (value, element) {
var pattern = new RegExp('^(?:(?:31(\/|-|\.)(?:0?[13578]|1[02]))\1|(?:(?:29|30)(\/|-|\.)(?:0?[1,3-9]|1[0-2])\2))(?:(?:1[6-9]|[2-9]\d)?\d{2})$|^(?:29(\/|-|\.)0?2\3(?:(?:(?:1[6-9]|[2-9]\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00))))$|^(?:0?[1-9]|1\d|2[0-8])(\/|-|\.)(?:(?:0?[1-9])|(?:1[0-2]))\4(?:(?:1[6-9]|[2-9]\d)?\d{2})$');
return this.optional(element) || pattern.test(value);
}
正如我在标题中写的那样,最小和最大日期的限制并不起作用(我也试图设定一个最小日期)。我不确定,但可能是由于cutom验证码。但是我怎么需要改变呢? P.S。我很抱歉,如果我的问题太容易了,但我不太了解JS。
答案 0 :(得分:1)
使用startDate和endDate可以设置
$(function () {
$('.datepicker input').datepicker({
language: "ru",
autoclose: true,
format: "dd.mm.yyyy",
todayHighlight: true,
startDate : new Date('2017-03-10'),
endDate : new Date()
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datepicker/1.6.4/js/bootstrap-datepicker.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-datepicker/1.6.4/css/bootstrap-datepicker.css" rel="stylesheet"/>
<div class="datepicker">
<input type='text' id='Birthdate'/>
</div>