web-dev-qa-db-fra.com

AngularJS - télécharger et afficher une image à l'aide de l'API FileReader (fichiers multiples)

J'utilise l'exemple suivant, cela fonctionne parfaitement, mais j'aimerais télécharger plusieurs images simultanément.

http://jsfiddle.net/kkhxsgLu/2/

<div ng-controller="MyCtrl">

<div ng-repeat="step in stepsModel">
    <img class="thumb" ng-src="{{step}}" />
</div>

<input type='file' ng-model-instant onchange="angular.element(this).scope().imageUpload(this)" />
 $scope.stepsModel = [];

$scope.imageUpload = function(element){
    var reader = new FileReader();
    reader.onload = $scope.imageIsLoaded;
    reader.readAsDataURL(element.files[0]);
}

$scope.imageIsLoaded = function(e){
    $scope.$apply(function() {
        $scope.stepsModel.Push(e.target.result);
    });
}

Merci de bien vouloir m'aider, j'ai commencé avec angularjs

5
Tony

SOLUTION:

http://jsfiddle.net/orion514/kkhxsgLu/136/

:)

<div ng-controller="MyCtrl">

<div ng-repeat="step in stepsModel">
    <img class="thumb" ng-src="{{step}}" />
</div>

<input type='file' ng-model-instant 
       onchange="angular.element(this).scope().imageUpload(event)"
       multiple />
$scope.stepsModel = [];

$scope.imageUpload = function(event){
     var files = event.target.files; //FileList object

     for (var i = 0; i < files.length; i++) {
         var file = files[i];
             var reader = new FileReader();
             reader.onload = $scope.imageIsLoaded; 
             reader.readAsDataURL(file);
     }
}

$scope.imageIsLoaded = function(e){
    $scope.$apply(function() {
        $scope.stepsModel.Push(e.target.result);
    });
}
18
Tony

Directive pour obtenir des fichiers avec ng-model (plusieurs fichiers)

La directive <input> intégrée à AngularJS ne gère pas <input type=file>. Il faut une directive personnalisée pour cela.

<input type="file" files-input ng-model="fileArray" multiple>

La directive files-input:

angular.module("app").directive("filesInput", function() {
  return {
    require: "ngModel",
    link: function postLink(scope,elem,attrs,ngModel) {
      elem.on("change", function(e) {
        var files = elem[0].files;
        ngModel.$setViewValue(files);
      })
    }
  }
})

La directive ci-dessus ajoute un écouteur de modification qui met à jour le modèle avec la propriété files de l'élément input.

Cette directive permet à <input type=file> de fonctionner automatiquement avec les directives ng-change et ng-form.

La DEMO sur PLNKR


Démo en ligne de la directive files-input

angular.module("app",[]);

angular.module("app").directive("filesInput", function() {
  return {
    require: "ngModel",
    link: function postLink(scope,elem,attrs,ngModel) {
      elem.on("change", function(e) {
        var files = elem[0].files;
        ngModel.$setViewValue(files);
      })
    }
  }
});
<script src="//unpkg.com/angular/angular.js"></script>
  <body ng-app="app">
    <h1>AngularJS Input `type=file` Demo</h1>
    
    <input type="file" files-input ng-model="fileArray" multiple>
    
    <h2>Files</h2>
    <div ng-repeat="file in fileArray">
      {{file.name}}
    </div>
  </body>
0
georgeawg

Zypps987, essayez d'utiliser var fichier = fichiers [0], pas dans une boucle.

0
Guto Condé