AngularUI datepicker-popup - 手动键入日期和最小/最大日期

use*_*318 4 validation datepicker angularjs angular-ui

我发现在使用datepicker-popup时验证手动键入的日期值超出minDate或maxDate值的问题.

这可以通过角度ui站点上的datepicker弹出窗口来演示,方法如下:http://angular-ui.github.io/bootstrap/#/datepicker

  1. 确保打开最小日期选项(最小日期应该等于今天)
  2. 在昨天的日期输入datepicker-popup

这显示了内联日期选择器周围的红色边框(因为它被标记为ng-invalid-date),但是datepicker-popup的输入框仍然有效.

在进一步调查中,似乎已经针对datepicker的弹出部分设置了ng-invalid-date属性,而不是针对输入框.这会导致问题,因为首先,用户无法看到元素无效,其次弹出窗口没有name属性,因此我无法检查ng-form的有效性(例如myForm.myDate.$ invalid

有没有人知道这方面的任何方式?

lmy*_*ers 9

您可以对文本字段的ng-change和该字段的setValidity进行额外验证,以达到您想要的效果.这是一个展示这个想法的傻瓜.

http://plnkr.co/edit/N9Hk9QFIfj3IXfHoWwbt?p=preview

我添加了一个小的CSS样式,以便在字段无效时显示红色边框.有效性测试非常基础; 你想要增强它以允许当天.

  • 如果需要进行额外的更改()验证,最小和最大日期的角度是多少?他们只是默认值吗? (6认同)