【问题标题】:AngularJS 'controller as' and form.$validAngularJS 'controller as' 和 form.$valid
【发布时间】:2015-07-15 00:11:32
【问题描述】:

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

当我尝试访问 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);
    };
}]);

【问题讨论】:

    标签: angularjs angularjs-validation


    【解决方案1】:

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

    编辑

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

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

    【讨论】:

    【解决方案2】:

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

    <form name="main.contactForm" novalidate>
    

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

    【讨论】:

    • 此解决方案不直观。您已经在模板中使用 $scope。您应该将 $scope 注入控制器,而不是在表单名称前加上奇怪的名称,例如“main”、“$ctrl”或“$vm”。
    • 是的..你明白了。
    • @ismailarilik 什么是直观的,也许是透视问题? stackoverflow.com/a/30644370/1061668
    【解决方案3】:

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

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

    【讨论】:

      【解决方案4】:

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

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

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2016-10-30
        • 2022-01-21
        • 1970-01-01
        • 2015-10-23
        • 2014-12-03
        • 2014-10-08
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多