美文网首页es6
Angular6 post请求封装

Angular6 post请求封装

作者: 曼珠沙华_521b | 来源:发表于2019-02-21 11:32 被阅读0次

文件名:http.service.ts
import{ Injectale} from '@angular/core';
import {HttpClient,HttpHeaders,HttpErrorResponse} from 'angular/common/http';
import {Observable,throwError,of} from'rxjs';
import {catchError,map,tap} from'rxjs/operators';
const httpOptions={
headers:new HttpHeaders({'Content-Type':"application/json"})}
@Injectable({providedIn:'root'})

export class HttpService{
constructor(private http:HttpClient){}
pulblic postHttp(url :string ,data={}):Observable<any>{
return this.http.post(${url},data,httpOptions).pipe(map(this.extractData),catchError(this.handleError))}

//返回数据
private extractData(res:Response){
let body=res;
return body || {}
}
//返回错误信息
privtae handleError(error:HttpErrorResponse){
if(error.error instance ErrorEvent){
conse.log('an error occurred ',error.error.message)}
else{
conse.error{
'backed return code {error.status},+ body was:${error.error}'

}
return throwError('something bad happend;please try again later')
}

}

}

相关文章

网友评论

    本文标题:Angular6 post请求封装

    本文链接:https://www.haomeiwen.com/subject/kkcryqtx.html