2017-09-01 57 views
0

当我执行此脚本时,aForm.aField。$ error包含{“required”:true}但是$ scope.fruit未设置为undefined,即使它不是在md选项值中。因此,“必需”验证已完成,但未设置为未定义。角度材质md-select ng-model设置为未定义规则

<!doctype html> 
<html ng-app="anApp"> 

<head> 
    <link rel="stylesheet" href="bower_components/angular-material/angular-material.min.css"> 
    <script src="bower_components/angular/angular.js"></script> 
    <script src="bower_components/angular-messages/angular-messages.min.js"></script> 
    <script src="bower_components/angular-material/angular-material.js"></script> 
    <script src="bower_components/angular-animate/angular-animate.min.js"></script> 
    <script src="bower_components/angular-aria/angular-aria.min.js"></script> 
    <script> 
     angular.module('anApp', ['ngMessages', 'ngMaterial']) 
      .controller('aController', function ($scope, $timeout) { 
       $scope.fruitBasket = [{name:"apple", id:1}]; 
       $scope.fruit = 100; 
       $scope.required = true; 
      }); 
    </script> 
</head> 

<body ng-controller="aController"> 
    {{aForm.aField.$error}}<br> [{{fruit}}] 
    <br> 

    <form name="aForm"> 
     <md-input-container> 
      <label>Fruit</label> 
      <md-select name="aField" ng-required="required" ng-model="fruit"> 
       <md-option ng-repeat="unFruit in fruitBasket" ng-value="unFruit.id"> {{unFruit.name}} </md-option> 
      </md-select> 

      <div ng-messages="aForm.aField.$error"> 
       <div ng-message="required">Fruit required</div> 
      </div> 
     </md-input-container> 
    </form> 
</body> 

</html> 

但是,当我执行这个脚本,$ scope.fruit被执行后超时设置为undefined:

<!doctype html> 
<html ng-app="anApp"> 

<head> 
    <link rel="stylesheet" href="bower_components/angular-material/angular-material.min.css"> 
    <script src="bower_components/angular/angular.js"></script> 
    <script src="bower_components/angular-messages/angular-messages.min.js"></script> 
    <script src="bower_components/angular-material/angular-material.js"></script> 
    <script src="bower_components/angular-animate/angular-animate.min.js"></script> 
    <script src="bower_components/angular-aria/angular-aria.min.js"></script> 
    <script> 
     angular.module('anApp', ['ngMessages', 'ngMaterial']) 
      .controller('aController', function ($scope, $timeout) { 
       $scope.fruitBasket = [{name:"apple", id:1}]; 
       $scope.fruit = 100; 
       $scope.required = false; 

       $timeout(function() { 
        $scope.required = true; 
       }, 1000); 

      }); 
    </script> 
</head> 

<body ng-controller="aController"> 
    {{aForm.aField.$error}}<br> [{{fruit}}] 
    <br> 

    <form name="aForm"> 
     <md-input-container> 
      <label>Fruit</label> 
      <md-select name="aField" ng-required="required" ng-model="fruit"> 
       <md-option ng-repeat="unFruit in fruitBasket" ng-value="unFruit.id"> {{unFruit.name}} </md-option> 
      </md-select> 

      <div ng-messages="aForm.aField.$error"> 
       <div ng-message="required">Fruit required</div> 
      </div> 
     </md-input-container> 
    </form> 
</body> 

</html> 

当我看角的代码,调用$$ runValidators的时候,有这个“prevValid”条件,似乎影响“设置为undefine”机制。

因此,似乎md-select(因为角度)并不总是将模型设置为undefined,因为它不是有效值。

如果我希望我的第一个脚本(没有超时的脚本)将模型设置为未定义,因为它的值不在md选项值中,该怎么办?

这些行为是否记录在某处?

有什么规则?

+0

检查此plkn https://embed.plnkr.co/9jvwE1l1HdmeRQkqOVoF/ –

+0

谢谢耶稣卡拉斯科 – Leto

回答

0

以及最后我发现在角DOC答案... ...每一个注册的验证器(第一同步验证,然后异步验证)的

上运行。如果有效性更改为无效,则模型将设置为undefined,除非ngModelOptions.allowInvalid为true。如果有效性更改为有效,它会将模型设置为最后一个可用的有效$ modelValue,即最后解析的值或从范围中设置的最后一个值。

事实上,当字段设置为required时,有效性状态从true变为false。

相关问题