angular 的 http 多了 Request, Headers, Response ,这些都是游览器的“新特性” Fetch API.

Fetch API 和以前的 xmlhttprequest 主要功能是一样的,就是发请求.

不同的地方是Fetch 是基于 promise 的,而且可以配合 service worker, stream, cache 之类的 "新特性" 打出连环计.

refer :

https://angular.cn/docs/ts/latest/guide/server-communication.html
https://xgrommx.github.io/rx-book/index.html
http://wiki.jikexueyuan.com/project/android-weekly/issue-145/introduction-to-RP.html

下面记入一些例子和小区别 :

不同的地方 :
1.不支持 ng1 的 interceptor 拦截和 transformations (要自己实现可以试着继承 http 服务来扩展)
2.默认结合rxjs (也可以很容易的转化回熟悉的 Promise)

提醒:
1.XSRF 和 ng1 一模一样
2.ng 有一个内存 WebAPI 服务 ( in-memory web api service ),可以模拟后端的 Web API 服务器. 不过我没有用 ^^".

例子 :

一、request

注意: get,post,put,delete 最终也是会调用 request 方法

代码
let options = new RequestOptions({
method: RequestMethod.Post,
url: "/api/products",
headers: new Headers({ 'Content-Type': 'application/json' }),
body: JSON.stringify({ code: "mk200" })
});
this.http.request(new Request(options)).toPromise().then((response) => {
//do something...
});

二、具体方法

1.get

1.1、参数和请求头

代码
let headers = new Headers({ "myHeader": "myValue" });
headers.append("Accept", "application/json");
let params = new URLSearchParams();
params.set('myParam', 'myValue');
let options = new RequestOptions({ headers: headers, search: params });
this.http.get("/api/products", options).toPromise().then((response) => {
console.log(response.json());
});

1.2、get CSV

let options = new RequestOptions({ responseType: ResponseContentType.Text });
this.http.get("/demo.csv", options).toPromise().then((response) => {
console.log(response.text());
});

2.POST

2.1、普通post

代码
let body = JSON.stringify({
code : "mk200"
});
let headers = new Headers({ 'Content-Type': 'application/json' }); //其实不表明 json 也可以, ng 默认好像是 json
let options = new RequestOptions({ headers: headers });
this.http.post("/api/products", body, options).toPromise().then((response) => {
//do something...
});

2.2、上传文件

<input type="file" (change)="onFileChanged($event.target.files)" placeholder="Upload file" accept="image/*">
代码
onFileChanged(fileList: FileList) {
if (fileList.length > 0) {
let file: File = fileList[0];
let formData: FormData = new FormData();
formData.append('uploadFile', file, file.name);
let headers = new Headers({
"Accept": "application/json"
});
let options = new RequestOptions({ headers });
this.http.post("https://localhost:44372/api/uploadFile", formData, options)
.map(res => res.json())
.catch(error => Observable.throw(error))
.subscribe(
data => console.log('success' + data),
error => console.log(error)
)
}
}
代码
ng 支持 formData, 关键就是别自己去写 Content-Type header, ng 会帮我们写好的.

三、拦截

ng 并没有给我们一个拦截的接口, 不过我们可以通过简单的继承+override 来达到目的.

refer : http://stackoverflow.com/questions/34934009/handling-401s-globally-with-angular-2

代码
import { Injectable } from '@angular/core';
import { Http as NgHttp, XHRBackend, RequestOptions, Request, RequestOptionsArgs, Response } from "@angular/http";

import { Observable } from "rxjs/Observable";

@Injectable()
export class Http extends NgHttp {
constructor(backend: XHRBackend, defaultOptions: RequestOptions) {
super(backend, defaultOptions);
}
get(url: string, options?: RequestOptionsArgs): Observable<Response>
{
console.log("in");
return super.get(url,options);
}

request(url: string | Request, options?: RequestOptionsArgs): Observable<Response> {    
console.log("in2");
return super.request(url, options).catch((error: Response) => {
console.log(error);
return Observable.throw(error);
});
}
}
代码
因为get,post,put,delete 最终也是会调用 request 方法, 所以我们可以在 request 做大部分的拦截.

typescript 中 override 父类方法不需要写什么 virtual, override 之类的, 直接写方法就可以了, 内部通过 super.method() 来调用父类方法, 不是 super() 哦.

我们有 2 个选择来调用这个 http, 第一就是声明我们的 service, 其二是覆盖 ng 的 Http service.

代码
import { Http as StoogesHttp } from "./http.service";
import { Http } from "@angular/http";

@NgModule({
imports: [StoogesModule, DebugRoutingModule],
exports: [],
declarations: [DebugComponent],
providers: [{ provide : Http, useClass : StoogesHttp }] //这样就覆盖掉了. 可以参考我写的 angular2 依赖注入
})
export class DebugModule {

}

最新文章

  1. MySql access denied for user错误
  2. 详细讲解Linux驱动程序
  3. 利用SlidingPaneLayout实现侧滑
  4. Linux cat命令
  5. PHP内核探索之变量(2)-理解引用
  6. [翻译]lpeg入门教程
  7. 关于图片加载非常爽的一个三方控件 fresco,一个三fresco
  8. SOD 精选细节--常用工具
  9. phpQuery采集微信公众号文章乱码
  10. mysql查看日志
  11. 【转】myeclipse 上安装 Maven3
  12. ExtJs的事件机制Event(学员总结)
  13. linus用的是哪个桌面?
  14. DevExpress中ChartControl柱状图(Bar)用法
  15. 今天遇到的面试题for(j=0,i=0;j&lt;6,i&lt;10;j++,i++) { k=i+j; } k 值最后是多少?
  16. 又是一个愚蠢的错误,皆因.xml而起
  17. SpriteBuilder中的CCSprite9Slice是个什么鬼?
  18. java中的函数
  19. ERP新人防坑指南
  20. docker部署nginx

热门文章

  1. SLIC superpixel算法
  2. 17.HTML
  3. Intellij +Maven 报错: Dmaven.multiModuleProjectDirectory system property is not set. Check $M2_HOME environment variable and mvn script match.
  4. Win7硬盘的AHCI模式
  5. Navicat通过跳板机连接数据库
  6. BAT脚本/Dos 改ip地址
  7. java 三种工厂模式
  8. nodejs批量导入数据eventproxy(回调函数嵌套解决方案)使用实例
  9. 总结的Javascript插件
  10. Laravel 模型事件入门