0

我有一个表格,它包括输入字段,您可以输入金额。它具有最大属性。如果用户输入的金额大于最大值,我想设置 ng-model 参数值来设置最大值,这是 RESTFull API 的响应。

直接将 JSON 对象值分配给 max 属性。最大值以字符串形式键入作为 API 的响应。

我在分配属性值时使用了货币过滤器。

如何将最大属性值设置为 ngModel 对象的值?如果用户输入的值大于最大值?有没有办法立即更改它并同时更新输入字段?

另外请告诉我,如果我使用过滤器是真的吗?或不?

<input type="text" name="payableamount" class="form-control input-lg"
                       min="{{amount | currency:'':2}}"
                       max="{{billObj.amount | currency:'':2}}"
                       ng-model="form.bidAmount"
                       ng-required="true" ui-number-mask>
4

1 回答 1

1

存储您从 API 获得的 maxAmount 的值,并在“checkAmount”函数中对其进行验证

1.使用ngKeyup:

//html    
<input ng-model="amount" ng-keyup="checkAmount($event,amount)"/>

//js
function MyCtrl($scope, $log) {

    $scope.checkAmount = function(e,amt) {
      if(amt>10){ //assuming maxAmount is 10
          $scope.amount = 10;
          e.preventDefault();
        }
    };
}

2.使用指令,

<input check-max ng-model="amount"/>


myApp.directive('checkMax', function() {
    return {
    restrict: 'AE', //attribute or element,
    require: 'ngModel',
    link:function(s,e,a,ngModel){
        e.bind('keyup',function(event){
        if(ngModel.$modelValue>10){
          event.preventDefault();
          ngModel.$setViewValue(10);
          ngModel.$render();
        }
      });
    }
  };
});

小提琴(使用 ng-keyup):http: //jsfiddle.net/r74a5m25/202/

小提琴(使用指令):http: //jsfiddle.net/r74a5m25/203/

于 2016-08-03T09:18:25.090 回答