我正在尝试读取CSV或Excel文件,以便将其转换为表格。 现在,我只是创建了一个类以读取输入文件:
输入为:
<input type="file" class="form-control-file" id="file_upload">
现在我只创建了一个类以读取输入文件:
class InputReader_tiqet{
constructor(input_id) {
this.inputId=input_id;
this.filetoLoad=document.getElementById("file_upload").files[0];
}
readFileData(){
this.filetoLoad = document.getElementById(this.inputId).files[0];
var fileReader = new FileReader();
fileReader.onload = function(fileLoadedEvent){
this.fileData = fileLoadedEvent.target.result;
};
fileReader.readAsText(this.fileToLoad, "UTF-8");
}
getData(){
return this.fileData;
}
}
我按如下方式运行它:
inputReader_object= new InputReader_tiqet("file_upload");
$("#file_upload").on('change', function(){
inputReader_object.readFileData();
//clean input field
this.val("");
});
输入文件更改时,出现以下错误:
Uncaught TypeError: Failed to execute 'readAsText' on 'FileReader': parameter 1 is not of type 'Blob'.
答案 0 :(得分:1)
问题已解决:this.filetoLoad而不是this.fileToLoad。