AngularJS 'controller as' и form.$ Valid
Я хочу проверить, является ли форма действительной внутри углового контроллера. Это кажется простым при использовании $ scope, но я не могу заставить его работать с синтаксисом "контроллер как".
Когда я пытаюсь получить доступ к форме. $ Valid, я получаю сообщение об ошибке "Не удается прочитать свойство" $ valid "из undefined".
plunkr: http://plnkr.co/edit/w54i1bZVD8UMhxB4L2JX?p=preview
HTML
<div ng-app="demoControllerAs" ng-controller="MainController as main">
<form name="contactForm" novalidate>
<p>
<label>Email</label>
<input type="email" name="email" ng-model="main.email" required />
</p>
<p>
<label>Message</label>
<textarea name="message" ng-model="main.message" required></textarea>
</p>
<input type="submit" value="submit" ng-click="main.submit()" />
</form>
</div>
JS
var app = angular.module('demoControllerAs', []);
app.controller('MainController', [function () {
var main = this;
main.submit = function () {
var isValid = main.contactForm.$valid;
console.log(isValid);
};
}]);
4 ответа
Вы можете сделать, как предложено @ons-jjss, но если вы предпочитаете не вводить $scope
в свой контроллер, а затем просто измените form
назвать как
<form name="main.contactForm" novalidate>
и это будет работать как шарм.
Вам нужно использовать таким образом: $scope.contactForm.$valid
РЕДАКТИРОВАТЬ
Для работы вышеупомянутого синтаксиса необходимо вставить $scope в контроллер.
app.controller('MainController', function($scope) {
//code
}
Вам нужно использовать main.contactForm
в атрибуте имени формы, то это решено. Видеть это
`http://plnkr.co/edit/us8MKU3LZ7pnLV66xIrv?p=preview`
Вы можете передать свою форму в качестве параметра для функции submit как ng-click="main.submit(contactForm)
а затем проверить его в методе контроллера