Обязательный атрибут Не работает с вводом файла в Angular Js
У меня есть контроль загрузки файлов в моей форме. Я использую Angular JS . Когда я ставлю обязательный атрибут, чтобы проверить, что файл выбран, он не работает.
<input id="userUpload" name="userUpload" required type="file" accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" />
<button type="submit" class="btn btn-primary"><i class="icon-white icon-ok"></i> Ok</button>
Подскажите, пожалуйста, почему не работает необходимый?
2 ответа
Решение
Это ngModelController, который выполняет проверку в Angular на основе таких атрибутов, как require
, Тем не менее, в настоящее время нет поддержки input type="file"
с сервисом ng-model. Чтобы заставить его работать, вы можете создать директиву, подобную этой:
app.directive('validFile',function(){
return {
require:'ngModel',
link:function(scope,el,attrs,ngModel){
//change event is fired when file is selected
el.bind('change',function(){
scope.$apply(function(){
ngModel.$setViewValue(el.val());
ngModel.$render();
});
});
}
}
});
Пример разметки:
<div ng-form="myForm">
<input id="userUpload" ng-model="filename" valid-file name="userUpload" required type="file" accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" />
<button ng-disabled="myForm.$invalid" type="submit" class="btn btn-primary"><i class="icon-white icon-ok"></i> Ok</button>
<p>
Input is valid: {{myForm.userUpload.$valid}}
<br>Selected file: {{filename}}
</p>
</div>
Посмотрите на мой рабочий пример plnkr.
Расширяя код @joakimbl, я предложу прямой, как это
.directive('validFile',function(){
return {
require:'ngModel',
link:function(scope,el,attrs,ctrl){
ctrl.$setValidity('validFile', el.val() != '');
//change event is fired when file is selected
el.bind('change',function(){
ctrl.$setValidity('validFile', el.val() != '');
scope.$apply(function(){
ctrl.$setViewValue(el.val());
ctrl.$render();
});
});
}
}
})
и в HTML вы можете использовать как это
<input type="file" name="myFile" ng-model="myFile" valid-file />
<label ng-show="myForm.myFile.$error.validFile">File is required</label>