3

私はこのコードを持っています:

 <div class="row" ng-repeat="input in inputs | filter:inputNumber">
     <ng-form name="form1">
       <div class="col-xs-3">
            <div class="form-group">
                 <input ng-model="inputs.number[$index]" type="number" name="number$index" class="form-control" placeholder="" min="1" max="9999" required />
                     <small class="label label-danger" data-ng-show="submitted && form1.number$index.$error.required">required</small>
                     <small class="label label-danger" data-ng-show="submitted && form1.number$index.$error.number">number</small>
                     <small class="label label-danger" data-ng-show="submitted && form1.number$index.$error.max">number max</small>
            </div>
        </div>
      </ng-form>
  </div>

 <button data-ng-click="add(form1)" class="btn-add" style="padding-left: 40%;"></button>

コントローラ:

// Form add handler.
$scope.add = function(form) {
    // Trigger validation flag.
    $scope.submitted = true;

    // If form is invalid, return and let AngularJS show validation errors.
    if (form.$invalid) {
        console.log('invalid');
        return;
    } else {
        var newItemNo = $scope.inputs.length + 1;
        var inputs = { 'id': 'input' + newItemNo }
        $scope.inputs.push(inputs);
        $scope.isDisabled = false;
    }
};

問題は、ng-repeat と ng-form 内のフォーム入力のみを検証できることです。その html ブロッ​​クの外側でイベントをトリガーする必要があります。助けていただければ幸いです。前もって感謝します。

4

1 に答える 1

3

あなたのコメントに基づいて、ng-repeat の各要素のフォームを生成するという同じ目標に従うと、これが答えになるはずです。

html

<form name="generalForm"> <!-- this form will be valid if all sub-forms are valid-->
 <div class="row" ng-repeat="input in inputs | filter:inputNumber">
     <ng-form name="form1">
       <div class="col-xs-3">
            <div class="form-group">
                 <input ng-model="inputs.number[$index]" type="number" name="number$index" class="form-control" placeholder="" min="1" max="9999" required />
                     <small class="label label-danger" data-ng-show="submitted && form1.number$index.$error.required">required</small>
                     <small class="label label-danger" data-ng-show="submitted && form1.number$index.$error.number">number</small>
                     <small class="label label-danger" data-ng-show="submitted && form1.number$index.$error.max">number max</small>
            </div>
        </div>
      </ng-form>
  </div>

 <button data-ng-click="add(generalForm)" class="btn-add" style="padding-left: 40%;"></button>
</form>

コントローラ

// Form add handler.
$scope.add = function(form) {
    // Trigger validation flag.
    $scope.submitted = true;

    // If form is invalid, return and let AngularJS show validation errors.
    if (form.$invalid) {
        console.log('invalid');
        return;
    } else {
        var newItemNo = $scope.inputs.length + 1;
        var inputs = { 'id': 'input' + newItemNo }
        $scope.inputs.push(inputs);
        $scope.isDisabled = false;
    }
};
于 2016-12-02T21:25:30.247 に答える