将指令的功能合并到Angular表单验证中

时间:2015-11-24 23:14:24

标签: javascript angularjs forms validation

我有两个相关的问题:

首先:我有以下指令,其目的是验证input[type=file]是否有效,但我不知道它是如何做到的最重要的是什么,实际代码意味着,这里是:

angular.module('sccateringApp')
  .directive('fileModel', ['$parse', function($parse) {
      return {
          restrict: 'A',
          link: function(scope, element, attrs) {
              var model = $parse(attrs.fileModel);
              var modelSetter = model.assign;
              element.bind('change', function(){
                  scope.$apply(function(){
                      modelSetter(scope, element[0].files[0]);
                  });
              });
          }
      };
  }]);

就像我说的,我不知道上面的代码实际上是做什么的,我从论坛中得到的解释是,它验证了输入类型文件。它是否正确? (到目前为止,我还无法验证它是否有效,因为它不能与我目前用来验证表单的代码一起使用)。

第二:使用下面的表格,使用角形式验证,它不允许点击提交按钮,直到表单中的实际输入符合验证规则(输入类别的名称) ,描述的最大长度为144个字符)。我将指令包含在文件输入中,但是表单的实际ng模型忽略了输入类型文件中的必需项,只验证了前两个输入的规则是否满足。

这是我的表格:

<form method="post" role="form" name="newCategoryForm" ng-submit="submitForm()" enctype="multipart/form-data" novalidate>
                    <div class="row">
                        <div class="row">
                            <div class="col s12">
                                <div input-field>
                                    <input type="text" name="cat-name" id="cat-name" ng-class="{ 'ng-invalid' : newCategoryForm.catname.$invalid && !newCategoryForm.catname.$pristine }"
                                    ng-model="catname" required>
                                    <label>Nombre</label>
                                </div>
                            </div>
                        </div>
                        <div class="row">
                            <div class="col s12">
                                <div input-field>
                                    <textarea class="materialize-textarea" name="cat-description" id="cat-description" length="144"
                                    ng-model="catdescription" ng-maxlength="144" required></textarea>
                                    <label>Descripción</label>
                                </div>
                            </div>
                        </div>
                        <div class="row">
                            <div class="col s12">
                                <h6>Imagen de Fondo</h6>
                                <div class="file-field input-field">
                                    <div class="btn pink darken-2 waves-effect waves-light">
                                        <span>Archivo</span>
                                        <input type="file" name="cat-bgimg" id="cat-bgimg"
                                        file-model="variable" required>
                                    </div>
                                    <div class="file-path-wrapper">
                                        <input class="file-path" type="text">
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                    <button type="submit" class="btn btn-large pink darken-2 waves-effect waves-light center-button" ng-disabled="newCategoryForm.$invalid">Crear Categoría</button>
                </form>

前两个输入得到正确验证,第三个输入(文件输入)没有,我真的不知道为什么因为指令被包含在输入中(我原来知道,ngModel不验证文件输入) 。

有关如何解决这个问题的任何想法或建议?我是Angular的新手,所有的教程都没用。我来自5年的jQuery工作经验,转向Angular并不容易。

1 个答案:

答案 0 :(得分:0)

上面发布的指令用于使提交获取<input type="file"></input>中找到的数据。

此外,应在控制器中初始化变量,以便将表单中找到的值复制到所述变量,然后需要将此变量作为参数发送到ng-submit="submitForm()内。

示例:

angular.module('sccateringApp')
  .controller('newSubcategoryController', function (httpcalls, $scope) {
    ...
    $scope.subcategory = [];
    ...
    $scope.submitForm = function(subcategory){
      ...
      $scope.request.insertSubcategory(subcategory);
    }
  });

表单中的每个ng模型都是:

<input type="text" ng-model="category.name">

这样控制器中的类别变量就可以获得该值。