Я должен сделать специальную директиву для проверки формы. Таким образом, все текстовые входы будут отображаться этой директивой. Директива должна показывать ошибки валидации по мере необходимости.Специальная директива по проверке подлинности
директива вызова:
<ff-inputbox data-type="text" data-class="form-control" ng-model="newQuote.zipcode" data-name="zipcode" data-id="zipcode" data-placeholder="{{vocab.retrv_saveQuote.zip_lable}}" data-pattern="/^(\d{5}-\d{4}|\d{5})$/" data-required="required">
</ff-text>
директива:
app.directive('ffInputbox', [function ($parse) {
return {
scope: {
type : '@',
class : '@',
name : '@',
id : '@',
placeholder : '@',
pattern : '@',
required : '@'
},
restrict: 'E',
replace: true,
templateUrl: 'modules/common/directives/ff-inputbox.tpl.html',
link: function(scope, elem, attr){
var ar = scope.formName;
var ar1 = scope.name;
console.log(elem.$error);
}
};
}]);
ФФ-inputbox.tpl.html
<input type={{type}} class={{class}} name={{name}} id={{id}} placeholder={{placeholder}} ng-pattern={{pattern}} required={{required}} minLength="3"></input>
////// /////////////////////////// Теперь я думаю использовать ng-сообщения, для которых мне нужен список ошибок. Соответственно, я покажу сообщение об ошибке msg на условиях $ touched, $ valid, $. Это правильный подход? Как я могу получить список ошибок $ внутри функции ссылки? Или нужен ли контроллер здесь?
спасибо. Нужно ли мне требовать директивы ngMessages в моей настраиваемой директиве для этого? а также как ng-messages = "testForm [name]. $ error" работать? мне также нужно передать имя формы в качестве атрибута, а затем называть его {{formName}} [имя]. $ error? – Isha
Я попытался использовать то, что вы написали, но это дает мне ошибку: Контроллер 'ngMessages', требуемый директивой 'ngMessagesInclude', не может быть найден! – Isha
@Isha Вам необходимо ввести ngMessages в ваш модуль. Я обновил ответ. Взгляни. – Vivek