1

私はこのHTMLを持っています:

<input type="date" date="MM-dd-yyyy" required data-ng-model="customerFormData.customer.BirthDate" />

そして、これが私の指示です ( P. Kozlowski のこのフィドルから)

app.directive('date', function (dateFilter) {
    return {
        require: 'ngModel',
        link: function (scope, elm, attrs, ctrl) {
            debugger;
            var dateFormat = attrs['date'] || 'yyyy-MM-dd';
            var minDate = Date.parse(attrs['min']) || 0;
            var maxDate = Date.parse(attrs['max']) || 9007199254740992;

            ctrl.$parsers.unshift(function (viewValue) {
                var parsedDateMilissec = Date.parse(viewValue);
                if (parsedDateMilissec > 0) {
                    if (parsedDateMilissec >= minDate && parsedDateMilissec <= maxDate) {
                        ctrl.$setValidity('date', true);
                        return parsedDateMilissec;
                    }
                }

                // in all other cases it is invalid, return undefined (no model update)
                ctrl.$setValidity('date', false);
                return undefined;
            });

            ctrl.$formatters.unshift(function (modelValue) {
                return dateFilter(modelValue, dateFormat);
            });
        }
    };
});

dd-mm-jjjjしかし、私の日付フィールドは値を取得しません。(Duth 表記法)と言い続けます。

customerFormData.customer.BirthDateこれをテストするためにコードにの値を設定しましたが、前述のnew Date().getTime();ように機能しません。

私が達成したいのは、 ainput type dateが日付フィールドにバインドされることです。

4

0 に答える 0