3

我有一个要求,只有在输入模糊或按下输入时才应该更新模型,并且错误/成功消息只会在输入之后而不是在输入期间显示。以前我使用 AngularJS 1.2 rc2 并有以下代码:

Javascript:

angular.module('app', []).directive('ngModelOnblur', function () {
  return {
      restrict: 'A',
      require: 'ngModel',
      link: function (scope, element, attrs, ngModelCtrl) {
          if (attrs.type === 'radio' || attrs.type === 'checkbox') { return; }
          var update = function () {
              scope.$apply(function () {
                  ngModelCtrl.$setViewValue(element.val().trim());
                  ngModelCtrl.$render();
              });
          };
          element.off('input').off('keydown').off('change').on('focus', function () {
              scope.$apply(function () {
                  ngModelCtrl.$setPristine();
              });
          }).on('blur', update).on('keydown', function (e) {
              if (e.keyCode === 13) {
                  update();
              }
          });
      }
  };
})
.controller('Ctrl', ['$scope', function ($scope) {
  $scope.getClass = function (input) {
    if (input.$pristine) { return ''; }
    return input.$invalid ? 'has-error' : 'has-success';
  };
}]);

HTML:

<div ng-controller="Ctrl">
  <form name="form" novalidate>
    <div ng-class="getClass(form.firstname)">
      <input type="text" name="firstname" ng-model="firstname" ng-model-onblur ng-pattern="/^\d{4}$/" />
      <div class="error">error</div>
      <div class="success">success</div>
      $pristine: {{form.firstname.$pristine}}
    </div>
  </form>
</div>

CSS:

  .error, .success {
    display: none; 
  }
  .has-error .error, .has-success .success {
    display: block; 
  }

但自从我升级到 RC3 后,事情就开始崩溃了。尽管我删除了输入、更改和按键输入的事件处理程序,但 $pristine 在输入期间仍设置为 false,因此将显示消息。

我尝试为指令设置terminal: true, priority: -1,但它仍然不起作用。我究竟做错了什么?

这是 plunker:http ://plnkr.co/edit/8FliNc?p=preview

提前致谢

4

2 回答 2

2

如果你给你的指令优先级,它对我有用: 1. 设置 terminal = true 意味着 ng-model 永远不会被调用,我认为不支持优先级 -1。

http://plnkr.co/edit/mZyWw8?p=preview

我在指令中发现了一些小事情:当您重新聚焦输入时,模型被重置(表单设置为原始),即使模型有效。如果清空输入,则在设置模型后,模型不会设置为未定义。

于 2013-10-21T08:45:40.997 回答
1

我认为这现在在 Angular JS 中得到了原生支持。

请参阅:https ://docs.angularjs.org/api/ng/directive/ngModelOptions

我正在使用 angular 1.6 并且“updateOn:'blur'”似乎对我有用。

于 2020-01-20T16:25:51.863 回答