Angular 2 - 文件上传访问

时间:2016-10-20 06:07:17

标签: angular file-upload typescript

<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中执行此操作,因为我仍然需要处理文件中的数据(例如检查有效的文件类型)?

1 个答案:

答案 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);