我正在尝试将csv文件加载到AngularJS中,以便对内容进行一些操作。它并没有按照我想要的那样工作。为了测试它是否正确加载,我将它加载到文本区域以查看内容。
当我加载文件时,它说它加载正确,但在我加载第二个CSV文件之前,onload()事件似乎不会启动,在这种情况下,FIRST文件显示在文本区域。
HTML:
<div>
<input ng-model="csv"
onchange="angular.element(this).scope().fileChanged()"
type="file" accept=".csv" id="fileInput"/>
</div>
<br/>
<div>
<textarea ng-model="csvFile" readonly="true" style="width:99%; height:500px" disabled></textarea>
</div>
JS:
$scope.fileChanged = function() {
$scope.$apply(function() {
var csvFileInput = document.getElementById('fileInput');
var reader = new FileReader();
var csvFile = csvFileInput.files[0];
reader.onload = function(e) {
$scope.csvFile = reader.result;
};
reader.readAsText(csvFile);
});
};
当我将其放入JSFiddle时,该文件根本不会出现在文本区域中。我是JSFiddle的新手,所以我不知道为什么会发生这种情况。
任何帮助都将不胜感激。
重新排序代码的某些行,希望注释足够解释
$scope.fileChanged = function() {
// define reader
var reader = new FileReader();
// A handler for the load event (just defining it, not executing it right now)
reader.onload = function(e) {
$scope.$apply(function() {
$scope.csvFile = reader.result;
});
};
// get <input> element and the selected file
var csvFileInput = document.getElementById('fileInput');
var csvFile = csvFileInput.files[0];
// use reader to read the selected file
// when read operation is successfully finished the load event is triggered
// and handled by our reader.onload function
reader.readAsText(csvFile);
};
参考:MDN 的FileReader
这只是HTML:的一个小改进
<input type="file" onchange="angular.element(this).scope().file_changed(this)"/>
<textarea cols="75" rows="15">{{ dataFile }}</textarea>
和控制器:
.controller('MyCtrl', ['$scope', function($scope) {
var vm = $scope;
vm.file_changed = function(element){
var dataFile = element.files[0];
var reader = new FileReader();
reader.onload = function(e){
vm.$apply(function(){
vm.dataFile = reader.result;
});
};
reader.readAsText(dataFile);
};
}]);
参考
如果不想使用$scope.$apply()
,可以使用$timeout
:
const fileReader = new FileReader();
fileReader.onload = (event) => {
this.$timeout(() => {
// Logic goes here...
}, 0);
};
...