javascript – 具有动态名称的Angular验证表单

通常要在Angular中验证表单,我会在ng-submit指令中使用类似的东西:
<form name="formName" ng-submit="formName.$valid && submitForm()"></form>

当表单具有我在构建表单时设置的名称时,这非常有用.但是,在我目前的情况下,我正在尝试基于对象列表创建多个表单.在这种情况下,每个表单都有一个即时确定的名称.

用户提交其中一个表单时,如何在运行该表单的submitForm()函数之前验证它?

这是简化问题的一个方面:http://jsfiddle.net/flyingL123/ub6wLewc/1/

我的问题是,如何访问表单的名称以进行验证?这是小提琴的代码

var app = angular.module('app',[]);

app.controller("AppController",['$scope',function($scope) {
  $scope.forms = [{
    id: 1,value: "val1"
  },{
    id: 2,value: "val2"
  },{
    id: 3,value: "val3"
  }];

  $scope.submitForm = function() {
    alert('submitted');
  }
}]);
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular.min.js"></script>
<div id="app" ng-app="app" ng-controller="AppController">
  <div class="formWrapper" ng-repeat="form in forms">
    <form name="{{ 'form' + form.id }}" ng-submit="submitForm()" novalidate>
      <input ng-model="form.value" required />
      <button type="submit">Submit</button>
    </form>
  </div>
</div>

解决方法

您始终可以使用它来访问模板中的范围.
{{this.foo === foo}} <!-- This will always show "true" -->

因此,您只需使用此[myDynamicFormName]即可访问该表单:

<form name="{{'form' + form.id}}" ng-submit="this['form' + form.id].$valid && submitForm()"></form>

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...