<div class="fileUpload btn btn-primary">
<span>Choose File</span>
<input id="uploadBtn" type="file" class="upload" value="No File Selected" #uploadBtn/>
</div>
<input id="uploadFile" placeholder="No File Chosen" disabled="disabled" value="{{uploadBtn.value}}"/>
如何访问用户上传的文件?我如何在angular和typescript中执行此操作,因为我仍然需要处理文件中的数据(例如检查有效的文件类型)?
答案 0 :(得分:7)
几乎与您在JavaScript中的方式相同。
如果以上是您的名为FileUploadComponent
的组件的模板,您可以执行以下操作。请注意,这是HTML5
。浏览器支持来自IE10。
@Component({
selector: 'file-upload',
template: `
...
<input type="file" class="upload" (change)="_onChange($event.target.files)">
...`
})
export class FileUploadComponent {
private _onChange(files: FileList) : void {
if(files && files.length > 0) {
let file : File = files.item(0);
//Now you can get
console.log(file.name);
console.log(file.size);
console.log(file.type);
}
}
}
您可以使用FileReader
扩展此功能以加载文件。
例如,如果您想阅读csv
文件:
使用file
:
let reader: FileReader = new FileReader();
reader.onload = (e) => {
let csv: string = reader.result;
console.log(csv);
//From here you can either use a csv parse library, or your own
//implementation if you know what the structure of the csv is
}
reader.readAsText(file);