Voglio verificare se un modulo è valido all'interno di un controller angolare. Questo sembra semplice quando si usa $ scope, ma non riesco a farlo funzionare con la sintassi 'controller as'.
Quando si tenta di accedere al modulo. $ Valido Viene visualizzato il messaggio di errore "Impossibile leggere la proprietà '$ valido' di non definito".
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);
};
}]);
Grazie, è ovvio ora lo hai indicato. – ChaoticNadirs
buona soluzione :) –