我有两个相关的问题:
首先:我有以下指令,其目的是验证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并不容易。
答案 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">
这样控制器中的类别变量就可以获得该值。