使用Angular2的Http发送AJAX请求
使用Angular2的Http发送AJAX请求
Angular的文档并不详细,甚至API文档也有一些错误。经过查阅资料并经大量实验,终于明确了Angular的Http发送Ajax请求的方式方法。本文描述了通过Angular的Http发送Ajax请求相关的全部内容。
1. Angular的Http类
Angular的Http类负责与服务端通讯,通过Ajax的形式访问远程服务器。
Angular的Http访问远程服务器,可以使用GET、POST、PUT、DELETE、OPTIONS等方法(method)。
当然,我们最常使用的是GET和POST方法。
当Angular发现你所访问的地址是跨域的,会自动发送一次OPTIONS方法的请求,确定此跨域服务器是否支持跨域访问。若不支持跨域访问,则给出错误,不能执行真正的GET、POST请求。
2. 使用Angular发送GET请求
// 以下是一些必须的导入
import { Http, URLSearchParams,RequestOptions } from '@angular/http'; // 发送请求有关的类
import { Observable } from "rxjs"; // 明确请求后的可观察对象是Rx的可观察对象,如未指明是Rx的可观察对象,会报错。
import 'rxjs/add/operator/toPromise'; // 引入toPromise操作符,否则会报错,toPromise方法未定义。
// 发送get请求的方法
get() : Promise<string> {
let serverurl: string = "url地址";
// 创建请求参数对象,所有请求参数被放在此对象中。
let param = new URLSearchParams();
param.append("param1","test"); // 向请求参数中放入参数及值
// 创建请求设置对象,将请求参数作为其构造方法参数对象的"search"属性值。
// 请注意,在这里我们并未明确请求头(Headers),Angular会根据请求方法(method)
// 及请求参数的类型,自动确定请求头类型。
let options = new RequestOptions({search:param});
// 发起get请求。注意http属性必须由依赖注入而来。
return this.http.get(serverurl, options)
.toPromise() // 将可观察对象转为承诺,接下来按照承诺的方式处理。
.then(response => {
let data = response.json();
if (data.is_ok == 2) {
let result:string = data.rs;
console.log(result);
return Promise.resolve(result);
}
return Promise.reject("false");
}).catch(error => {
console.log(error);
return Promise.reject("false");
});
}
3. 使用Angular发送POST请求
// 以下是一些必须的导入
import { Http, URLSearchParams,RequestOptions } from '@angular/http'; // 发送请求有关的类
import { Observable } from "rxjs"; // 明确请求后的可观察对象是Rx的可观察对象,如未指明是Rx的可观察对象,会报错。
import 'rxjs/add/operator/toPromise'; // 引入toPromise操作符,否则会报错,toPromise方法未定义。
// 发送Post请求的方法
postByForm(): Promise<string> {
let serverurl: string = "url地址";
// 创建请求参数对象,所有请求参数被放在此对象中。
let param = new URLSearchParams();
param.append("param1","test"); // 向请求参数中放入参数及值
// 发起Post请求(http属性必须由依赖注入而来),请注意,post方法比get方法多了一个参数,多的是第2个参数。
// 第1个参数是url地址,第2个参数是请求参数;
// 第3个参数对应get方法的第2个参数,是请求设置(RequestOptions)对象。
// 在get请求中,我们将请求参数(URLSearchParams)放在了请求设置的(RequestOptions)对象的"search"属性中,
// 在post方法中,post请求参数作为post方法的第2个参数,不能放到请求设置的(RequestOptions)对象的"search"属性中。
// 如放到了请求设置的(RequestOptions)对象的"search"属性中,则被作为请求get参数的一部分。
// 如:url地址?param1=test,
// 这不是我们想要的。我们使用了post方法,即是希望在请求体的form-data部分传输我们的参数,
// 而不希望请求参数出现在url地址上。
// 在这里,请求设置对象是个null,因为我们不需要给本次请求设置请求头,请求头由anglar自动计算。
return this.http.post(serverurl, param, null)
.toPromise()
.then(response => {
let data = response.json();
if (data.is_ok == 2) {
let result:string = data.rs;
console.log(result);
return Promise.resolve(result);
}
return Promise.reject("false");
}).catch(error => {
console.log(error);
return Promise.reject("false");
});
}
4. 使用Angular以FormData对象作为参数发送POST请求
FormData是 XMLHttpRequest Level 2 新增的一个对象,在IE10及以上版本受支持,其他浏览器的新版本基本都支持。
FormData的结构就是一组键值对,键名是参数名,键值是参数值。它最大的特点是支持二进制流,所以我们使用FormData主要是用AJAX技术上传文件。上传文件时,文件是FormData中的一组键值对,除了文件以外的参数,也可以被放到FormData中一并提交给服务器。
// 以下是一些必须的导入
import { Http, URLSearchParams,RequestOptions } from '@angular/http'; // 发送请求有关的类
import { Observable } from "rxjs"; // 明确请求后的可观察对象是Rx的可观察对象,如未指明是Rx的可观察对象,会报错。
import 'rxjs/add/operator/toPromise'; // 引入toPromise操作符,否则会报错,toPromise方法未定义。
// 发送Post请求的方法
postByFormData(): Promise<string> {
let serverurl: string = "url地址";
let param = new FormData();
// 放入要上传的文件
let file = this.fileElement.nativeElement.files[0];
param.append("file",file);
// 放入其他参数
param.append("param1","test");
// 发送post请求(http属性必须由依赖注入而来),可以看到,除了第二个参数param的类型为FormData外,其余参数与普通post请求一致。
// angular会自动计算请求头类型。
return this.http.post(serverurl, param, null)
.toPromise()
.then(response => {
let data = response.json();
if (data.is_ok == 2) {
let result:string = data.rs;
console.log(result);
return Promise.resolve(result);
}
return Promise.reject("false");
}).catch(error => {
console.log(error);
return Promise.reject("false");
});
}
版权声明:本博文参考自 - https://blog.csdn.net/xin_bao_long/article/details/82798328
使用Angular2的Http发送AJAX请求的更多相关文章
- 在发送ajax请求时加时间戳或者随机数去除js缓存
在发送ajax请求的时候,为了保证每次的都与服务器交互,就要传递一个参数每次都不一样,这里就用了时间戳 大家在系统开发中都可能会在js中用到ajax或者dwr,因为IE的缓存,使得我们在填入相同的值的 ...
- 原生js发送ajax请求
堕落了一阵子了,今天打开博客,发现连登录的用户名和密码都不记得了.2016年已过半,不能再这么晃荡下去了. 参加了网易微专业-前端攻城狮 培训,目前进行到大作业开发阶段,感觉举步维艰.但是无论如何,不 ...
- jQuery发送ajax请求
利用jquery发送ajax请求的几个模板代码. $.ajax({ async : false, type: 'POST', dataType : "json", url: &qu ...
- JQuery发送ajax请求不能用数组作为参数
JQuery发送ajax请求不能用数组作为参数,否则会接收不到参数, 一.js代码如下: $('#delete-button').click(function(){ var select ...
- js中使用队列发送ajax请求
最近,项目中需要按照先后顺序发送ajax请求,并且在一次请求结束后才能发起下一次,不然就会导致逻辑错误. 解决办法是定义一个数组,保存ajax请求数据. 以下使用extjs4定义一个类 Ext.def ...
- IE6下a标签上发送ajax请求总是error
IE6下真是处处是坑啊!!!走过了一个又一个坑,记录一下吧. 之前不知道a标签上注册click事件之后,发送ajax请求总是error.后来经过几番网上搜索,终于找到高人遇到此坑的解决办法.原来是a标 ...
- Jquery发送ajax请求以及datatype参数为text/JSON方式
Jquery发送ajax请求以及datatype参数为text/JSON方式 1.方式一:datatype:'text' 2.方式二:datatype:'JSON' 3.使用gson-1.5.jar包 ...
- 【liferay】1、使用alloy-UI发送ajax请求
1.首先liferay要发送ajax请求,那么就需要在jsp中定义resourceURL <portlet:resourceURL var="workDeal" id=&qu ...
- Axios发送AJAX请求
目录 Axios 特征 axios提供主要三种发起请求的方式 方式一:直接axios实例直接call方式 方式二:通过axios实例提供的不同http请求方式的方法 方式三:其实是从第二种方式中单独提 ...
随机推荐
- C# Aspose.Cells导出xlsx格式Excel,打开文件报“Excel 已完成文件级验证和修复。此工作簿的某些部分可能已被修复或丢弃”
报错信息: 最近打开下载的 Excel,会报如下错误.(xls 格式不受影响) 解决方案: 下载代码(红色为新添代码) public void download() { string fileName ...
- python语法_算数运算+赋值运算符+比较运算符+逻辑运算符
算术运算符 + - * / 加减乘除 5/2 = 2.5 5//2 = 2 整除,地板除 5%2= 1 取余数 2**10 指数运算 2的10次方 算术优先级 无论多少级,都使用()小括号进行优先 ...
- 【Android】快速开发偷懒必备(二) 支持DataBinding啦~爽炸,一行实现花式列表[申明:来源于网络]
[Android]快速开发偷懒必备(二) 支持DataBinding啦~爽炸,一行实现花式列表[申明:来源于网络] 地址:http://blog.csdn.net/zxt0601/article/de ...
- VLAN之间通信-三层交换
实验目的 VLAN之间通信-三层交换 掌握配置VLANIF接口的方法 理解数据包跨VLAN路由的原理 掌握测试多层交换网络连通性的方法 实验原理 三层交换机在原有二层交换机的基础之上增加了路由功能,同 ...
- Linux命令 sed
一. 以行为单位进行操作. d:删除 $ nl passwd | sed '2,5d' # 删除第2~5行 $ nl passwd | sed '2d' # 删除第2行 $ nl passwd | ...
- linux --nginx篇
NGINX是什么? nginx是开源的,支持高性能的,高并发的www服务和代理服务软件,就是web服务器,nginx不但是一个优秀的web服务软件,还可以做反向代理,负载均衡,以及缓存服务使用. 优点 ...
- centOs6.5配置启动ssh
.非root用户则执行su或su - 或su root或su - root切换为root用户 2.查看SSH是否安装(检查是否装了SSH包) 输入命令:rpm -qa | grep ssh 注:若没安 ...
- JavaScript 世界万物诞生记
一. 无中生有 起初,什么都没有.造物主说:没有东西本身也是一种东西啊,于是就有了null: 现在我们要造点儿东西出来.但是没有原料怎么办?有一个声音说:不是有null嘛?另一个声音说:可是null代 ...
- Web开发——jQuery基础
参考: 参考W3School:jQuery 教程 参考:jQuery 参考手册 参考(常用):jQuery API 测试 JavaScript 框架库 - jQuery 测试 JavaScript 框 ...
- 浅析python中的装饰器decorator
最近学习python,其中decorator比较难理解,遂写一篇来总结供后续查阅. 定义一个函数,想在运行时动态的改变函数的功能,又不想改变函数本身的代码,可以使用高阶函数(可以使用函数作为参数) 装 ...