我想检查一个角度控制器内的表单是否有效。使用$ scope时,这似乎很简单,但是我无法使其与“ controller as”语法一起使用。
当我尝试访问form。$ valid时,出现错误消息“无法读取未定义的属性'$ valid'”。
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);
};
}]);
您可以按照@ ons-jjss的建议进行操作,但是如果您不想注入$scope
控制器,则只需将form
名称更改为
<form name="main.contactForm" novalidate>
它会像魅力一样起作用。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句