AngularUIを使用して日付を入力できる次のフォームコードがあります(日付は必須であり、米国の日付形式と一致する必要があります。例:MM / DD / YY):
<form name="form" ng-submit="createShipment()">
<!-- Shipment Date must be in MM/DD/YY format: -->
<input name="shipmentDate"
ng-pattern='/^[0,1]?\d{1}\/(([0-2]?\d{1})|([3][0,1]{1}))\/(([1]{1}[9]{1}[9]{1}\d{1})|([2-9]{1}\d{3}))$/'
ui-date="{ dateFormat: 'mm/dd/y' }" required ng-model="shipment.ShipmentDate" type="text">
<span ng-show="form.shipmentDate.$error.required">Date Required!</span>
<span ng-show="form.shipmentDate.$error.pattern">Incorrect Format, should be MM/DD/YY!</span>
<input class="btn-primary" ng-hide="!form.$valid" type="submit" value="Create">
</form>
必須フィールドの検証は正常に機能しますが、日付形式が正しく検証されておらず、常に「形式が正しくありません... 」というメッセージが表示されます。
他の場所で正常に機能するいくつかの異なる正規表現を試しましたが、それでも機能しません。また、AngularUI検証を試しましたが、どちらも機能しません。前もって感謝します!
アップデート:
検証は使用したAngularUIdatepickerと競合していると思いましたが、datepickerは日付を自動修正するため、datepickerを使用しない場合は、正規表現が機能する限り検証が機能します。datepickerを使用する場合は、他の検証はあまり必要ありません。