我使用Angular2,TypeScript发送一个文件,以及JSON数据到服务器。
下面是我的代码:
- import {Component,View,NgFor,FORM_DIRECTIVES,FormBuilder,ControlGroup} from 'angular2/angular2';
- import {Http,Response,Headers} from 'http/http';
- @Component({ selector: 'file-upload' })
- @View({
- directives: [FORM_DIRECTIVES],template: `
- <h3>File Upload</h3>
- <div>
- Select file:
- <input type="file" (change)="changeListener($event)">
- </div>
- `
- })
- export class FileUploadCmp {
- public file: File;
- public url: string;
- headers: Headers;
- constructor(public http: Http) {
- console.log('file upload Initialized');
- //set the header as multipart
- this.headers = new Headers();
- this.headers.set('Content-Type','multipart/form-data');
- this.url = 'http://localhost:8080/test';
- }
- //onChange file listener
- changeListener($event): void {
- this.postFile($event.target);
- }
- //send post file to server
- postFile(inputValue: any): void {
- var formData = new FormData();
- formData.append("name","Name");
- formData.append("file",inputValue.files[0]);
- this.http.post(this.url +,formData,{
- headers: this.headers
- });
- }
- }
如何将formData转换为字符串并将其发送到服务器。我记得在Angular1,你会使用transformRequest。
我欣赏任何指导或建议。
看看我的代码,但要注意。我使用async / await,因为最新的Chrome beta可以读取任何es6代码,这是通过TypeScript获得编译。所以,你必须用.then()替换asyns / await。
输入更改处理程序:
- /**
- * @param fileInput
- */
- public psdTemplateSelectionHandler (fileInput: any){
- let FileList: FileList = fileInput.target.files;
- for (let i = 0,length = FileList.length; i < length; i++) {
- this.psdTemplates.push(FileList.item(i));
- }
- this.progressBarVisibility = true;
- }
提交处理程序:
- public async psdTemplateUploadHandler (): Promise<any> {
- let result: any;
- if (!this.psdTemplates.length) {
- return;
- }
- this.isSubmitted = true;
- this.fileUploadService.getObserver()
- .subscribe(progress => {
- this.uploadProgress = progress;
- });
- try {
- result = await this.fileUploadService.upload(this.uploadRoute,this.psdTemplates);
- } catch (error) {
- document.write(error)
- }
- if (!result['images']) {
- return;
- }
- this.saveUploadedTemplatesData(result['images']);
- this.redirectService.redirect(this.redirectRoute);
- }
FileUploadService。该服务还存储上传进度$ property,在其他地方,你可以订阅它,并获得新的价值每500ms。
- import { Component } from 'angular2/core';
- import { Injectable } from 'angular2/core';
- import { Observable } from 'rxjs/Observable';
- import 'rxjs/add/operator/share';
- @Injectable()
- export class FileUploadService {
- /**
- * @param Observable<number>
- */
- private progress$: Observable<number>;
- /**
- * @type {number}
- */
- private progress: number = 0;
- private progressObserver: any;
- constructor () {
- this.progress$ = new Observable(observer => {
- this.progressObserver = observer
- });
- }
- /**
- * @returns {Observable<number>}
- */
- public getObserver (): Observable<number> {
- return this.progress$;
- }
- /**
- * Upload files through XMLHttpRequest
- *
- * @param url
- * @param files
- * @returns {Promise<T>}
- */
- public upload (url: string,files: File[]): Promise<any> {
- return new Promise((resolve,reject) => {
- let formData: FormData = new FormData(),xhr: XMLHttpRequest = new XMLHttpRequest();
- for (let i = 0; i < files.length; i++) {
- formData.append("uploads[]",files[i],files[i].name);
- }
- xhr.onreadystatechange = () => {
- if (xhr.readyState === 4) {
- if (xhr.status === 200) {
- resolve(JSON.parse(xhr.response));
- } else {
- reject(xhr.response);
- }
- }
- };
- FileUploadService.setUploadUpdateInterval(500);
- xhr.upload.onprogress = (event) => {
- this.progress = Math.round(event.loaded / event.total * 100);
- this.progressObserver.next(this.progress);
- };
- xhr.open('POST',url,true);
- xhr.send(formData);
- });
- }
- /**
- * Set interval for frequency with which Observable inside Promise will share data with subscribers.
- *
- * @param interval
- */
- private static setUploadUpdateInterval (interval: number): void {
- setInterval(() => {},interval);
- }
- }