gpt4 book ai didi

javascript - 无法使用 Angular.js 在数组中有序获取文件

转载 作者:行者123 更新时间:2023-12-03 07:57:27 24 4
gpt4 key购买 nike

我在 Angular.js 中使用 ng-file-upload 上传多个文件时遇到一个问题。我首先在下面解释我的代码。

<input type="file" class="filestyle form-control" data-size="lg" name="bannerimage" id="bannerimage"  ng-model="file" ngf-pattern="'image/*'" accept="image/*" ngf-max-size="2MB" ngf-min-height="100" ngf-resize="{width: 100, height: 100}"  custom-on-change="uploadFile" required="required" ngf-select="onFileSelect($file);"  ngf-multiple="true">
</div>
<label for="bannerimage" accesskey="B" ><span class="required">*</span> View Image</labe
<div style="padding-bottom:10px;" ng-repeat="pht in stepsModel">
<img ng-src="{{pht.image}}" border="0" name="bannerimage" style="width:70px; height:70px;" id="imgId">
</div>

我的 Controller 端代码如下。

$scope.stepsModel = [];
$scope.allFiles=[];
$scope.uploadFile = function(event){
console.log('event',event.target.files);
var files = event.target.files;
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() {
var data={'image':e.target.result};
$scope.stepsModel.push(data)
});
}
$scope.submitImage=function(){
console.log('all files',$scope.allFiles);
}
$scope.onFileSelect = function($files) {
$scope.allFiles.push($files);

}

这里我的问题是,当我检查 submitImage 函数中存在的控制台消息中的图像 url 数量时,如下所示。

all files [Blob, null, Blob, null, Blob]
0: Blob

1: null
2: Blob
3: null
4: Blob

Objectlength: 5v

这里我只上传了 3 个文件,但长度显示 5 意味着它不是连续出现的,假设第 0 个索引有一个文件,然后下一个文件占用第二个索引。这里我需要所有文件都应该出现连续。请帮助我。

最佳答案

我认为首先您需要检查为什么数组中存在空元素。将日志放入 onFileSelect 函数中,并在选择每个文件后检查 allFiles 数组。

关于javascript - 无法使用 Angular.js 在数组中有序获取文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34742234/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com