it-swarm.com.de

AngularJS - Hochladen und Anzeigen von Bildern mithilfe der FileReader-API (mehrere Dateien)

Ich verwende das folgende Beispiel, es funktioniert perfekt, aber ich möchte mehrere Bilder gleichzeitig hochladen.

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);
    });
}

Danke, hilf mir freundlich, ich fing mit anglejs an

5
Tony

LÖSUNG:

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

Direktive für die Eingabe von Dateien mit ng-model (mehrere Dateien)

Die in AngularJS integrierte <input>-Direktive verarbeitet <input type=file> nicht. Man braucht dazu eine benutzerdefinierte Direktive.

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

Die files-input Direktive:

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);
      })
    }
  }
})

Die obige Anweisung fügt einen Änderungslistener hinzu, der das Modell mit der Eigenschaft files des Elements input aktualisiert.

Mit dieser Anweisung kann <input type=file> automatisch mit den Anweisungen ng-change und ng-form arbeiten.

Die DEMO auf PLNKR


Inline Demo der files-input Direktive

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, versuchen Sie es mit var file = files [0], nicht in einer Schleife.

0
Guto Condé