9

我想检查一个表单在角度控制器中是否有效。使用 $scope 时这似乎很简单,但我无法让它与“控制器作为”语法一起使用。

当我尝试访问 form.$valid 时,我收到错误消息"Cannot read property '$valid' of 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

4 回答 4

11

您可以按照@ons-jjss 的建议进行操作,但如果您不想注入$scope控制器,则只需将您的form名称更改为

<form name="main.contactForm" novalidate>

它会像魅力一样发挥作用。

于 2015-05-05T10:14:03.600 回答
4

你需要这样使用:$scope.contactForm.$valid

编辑

要使用上述语法,需要在控制器中注入 $scope。

app.controller('MainController', function($scope) { 
  //code 
} 
于 2015-05-05T10:06:54.217 回答
0

您需要main.contactForm在表单名称属性中使用它才能解决。看到这个

`http://plnkr.co/edit/us8MKU3LZ7pnLV66xIrv?p=preview`
于 2015-05-05T10:33:27.270 回答
-1

您可以将表单作为参数传递给函数提交为 ng-click="main.submit(contactForm)

然后在控制器方法中验证它

于 2015-05-05T10:14:05.973 回答