javascript - 使用Primeng上传组件上传文件

标签 javascript angular typescript primeng

我会使用 upload component 在 Angular 中上传文件

这是我的 HTML:

<p-fileUpload mode="basic" name="demo[]" customUpload="true" accept="image/*" maxFileSize="1000000"  (uploadHandler)="upload($event)"></p-fileUpload>

在我的 ts 我打印参数值

upload(event) {
  console.log(event)
}

我只得到元数据而不是 blob 内容

{"files":[{"objectURL":{"changingThisBreaksApplicationSecurity":"blob:https://prime-ng-file-uploading.stackblitz.io/d429e761-c391-45fa-8628-39b603e25225"}}]}

我还会获取文件内容以通过 API 发送到服务器

Here's a stackblitz demo

最佳答案

在官方文档中有一个例子:

export class FileUploadDemo {
  uploadedFiles: any[] = [];
  constructor(private messageService: MessageService) {}
  onUpload(event) {
    for (let file of event.files) {
      this.uploadedFiles.push(file);
    }
    this.messageService.add({
      severity: 'info',
      summary: 'File Uploaded',
      detail: ''
    });
  }
}

当我使用 primeNG 时,我是这样做的(只上传 1 个文件):

HTML

 <p-fileUpload name="myfile[]" customUpload="true" multiple="multiple" (uploadHandler)="onUpload($event)" accept="application/pdf"></p-fileUpload>

component.ts

export class AlteracionFormComponent {
  uplo: File;
  constructor(private fileService: FileUploadClientService) {}
  onUpload(event) {
    for (let file of event.files) {
      this.uplo = file;
    }
    this.uploadFileToActivity();
  }
  uploadFileToActivity() {
    this.fileService.postFile(this.uplo).subscribe(data => {
      alert('Success');
    }, error => {
      console.log(error);
    });
  }
}

还有我的服务(在 Angular 中)

service.ts

  postFile(id_alteracion: string, filesToUpload: FileUploadModel[], catalogacion: any): Observable<any> {
    let url = urlAPIAlteraciones + '/';
    url += id_alteracion + '/documentos';

    const formData: FormData = new FormData();

    formData.append('json', JSON.stringify(catalogacion));

    for (let file of filesToUpload) {
      formData.append('documento', file.data, file.data.name);
    }

    console.log(formData);

    let headers = new HttpHeaders();

    return this._http.post(url, formData, { headers: headers });
  }

希望对你有帮助

关于javascript - 使用Primeng上传组件上传文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52292488/

相关文章:

javascript - 为什么在某些情况下单击鼠标中键不会触发 'click'?

javascript - 用户界面上弹出消息

Angular 2 提前编译器 : must I make all class properties public?

node.js - 如何让 formik 进行编译?

javascript - 使用 typescript 处理 Protractor 下拉列表的问题

javascript - 如何根据叶子值显示 JSON 树的特定路径?

JavaScript 二维数组未定义

angular - 如何在 Angular CLI 应用程序中提供 pdf.js worker

javascript - 在 Angular 6 中使用 slick.js 时出错

angular - 如何在构造函数中选择性地注入(inject) MAT_DIALOG_DATA