javascript - 通过验证将 Angular 形式输入到数组

标签 javascript arrays angularjs-ng-repeat

在 Angular JS 中是否有一种方法可以将管理器列表(或任何项目)推送到数组并在 Angular.js 中进行验证。我基本上想创建一个数组作为 ng-model 并仍然验证它。这是可以做到的还是我的做法是错误的?

    var app = angular.module("FormTest",[]);
    app.controller("AppCtrl",  ["$scope", function($scope){

        var appCtrl = this;
        appCtrl.appName = "Form Array";
        $scope.managers = [""];
        $scope.form = {};
        $scope.form.managers = $scope.managers;

        $scope.addManager = function(){

            $scope.managers.push('');
        }

        $scope.removeManager = function(index){

            if($scope.managers.length > 1){

                $scope.managers.splice(index, 1);

            }
        }

    }])

    angular.element(document).ready(function(){
        angular.bootstrap(document.querySelector('html'), ["FormTest"]);
    })
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
    <div ng-controller="AppCtrl as app">
        <h2>{{app.appName}}</h2>
        <div>
            {{form.managers}}
            <div>
                <div>{{managers}}</div>
                <div class="btn btn-primary" ng-click="addManager()">add manager</div>
            </div>
        </div>
        <form novalidate name="form">
            <div class="form-group" ng-repeat="item in managers track by $index">
                <div class="row-fluid">
                    <div class="col-md-5">
                        <input type="text" ng-model="managers[$index]" ng-pattern="/\w{3,}/" required class="form-control">
                    </div>
                    <div class="col-md-1">
                        <div class="btn btn-default">
                            <span class="glyphicon glyphicon-remove-circle" ng-click="removeManager($index)"></span>
                        </div>
                    </div>
                </div>
            </div>

        </form>
    </div>

最佳答案

在您的示例中,好吧,除了正则表达式。

看示例代码jsfiddle .

<h2>{{app.appName}}</h2>
<div>
  {{form.managers}}
  <div>
    <div>{{managers}}</div>
    <button class="btn btn-primary" ng-click="addManager()">add manager</button>
  </div>
</div>
<form novalidate name="form">
  Form valid={{form.$valid|json}}
  <div class="form-group" ng-repeat="item in managers track by $index">
    <div class="row-fluid">
      <div class="col-md-5">
        <input type="text" ng-model="managers[$index]" name="manager{{$index}}" ng-pattern="/^\w{3,}$/" required class="form-control">
        {{form['manager'+$index].$error}}
      </div>
      <div class="col-md-1">
        <div class="btn btn-default">
          <button class="glyphicon glyphicon-remove-circle" ng-click="removeManager($index)">Remove</button>
        </div>
      </div>
    </div>
  </div>

</form>

关于javascript - 通过验证将 Angular 形式输入到数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34998706/

相关文章:

javascript - 注入(inject) css 而无需从用户样式表转换

javascript - create-react-app 构建不接受样式

javascript - 值/占位符 - 单词的不同样式

arrays - O(n) 中的数组元素乘法算法

javascript - AngularJs 注入(inject)器模块错误

javascript - Angular Material Design 具有强制选择功能的自动完成文本框

arrays - 在 F# 数组函数中使用可区分联合时如何定义零元素

java - Android/Java 将文本文件中的名称存储在 String 数组中,并将整数存储在 int 数组中

javascript - 将 ng-repeat-start 和 ng-repeat-end 与 2 个不同的对象一起使用

angularjs - Angular ng 重复错误 "Duplicates in a repeater are not allowed."