AngularJS "контроллер as" и форма.$действительный


Я хочу проверить, допустима ли форма внутри углового контроллера. Это кажется простым при использовании $scope, но я не могу заставить его работать с синтаксисом 'controller as'.

Когда я пытаюсь получить доступ к форме.$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 7

4 ответа:

Вы можете сделать так, как предложил @ons-jjss, но если вы предпочитаете не вводить $scope в ваш контроллер, то просто измените свое form имя как

<form name="main.contactForm" novalidate>
И это сработает как заклинание.

Нужно использовать таким образом: $scope.contactForm.$valid

EDIT

Для работы вышеописанного синтаксиса, $scope должен быть injected в контроллере.

app.controller('MainController', function($scope) { 
  //code 
} 

Вам нужно использовать main.contactForm в атрибуте имени формы, тогда это решено. Смотрите это

`http://plnkr.co/edit/us8MKU3LZ7pnLV66xIrv?p=preview`

Вы можете передать свою форму в качестве параметра функции submit как ng-click="main.submit (contactForm)

И затем проверить его в методе контроллера