1.http请求

基本的操作由 $http 服务提供。它的使用很简单,提供一些描述请求的参数,请求就出去了,然后返回一个扩充了 success 方法和 error 方法的 promise对象(下节介绍),你可以在这个对象中添加需要的回调函数。

  1. var TestCtrl = function($scope, $http){
  2. var p = $http({
  3. method: 'GET',
  4. url: '/json'
  5. });
  6. p.success(function(response, status, headers, config){
  7. $scope.name = response.name;
  8. });
  9. }

$http 接受的配置项有:

  • method 方法
  • url 路径
  • params GET请求的参数
  • data post请求的参数
  • headers 头
  • transformRequest 请求预处理函数
  • transformResponse 响应预处理函数
  • cache 缓存
  • timeout 超时毫秒,超时的请求会被取消
  • withCredentials 跨域安全策略的一个东西

其中的 transformRequest 和 transformResponse 及 headers 已经有定义的,如果自定义则会覆盖默认定义:

  1. var $config = this.defaults = {
  2. // transform incoming response data
  3. transformResponse: [function (data) {
  4. if (isString(data)) {
  5. // strip json vulnerability protection prefix
  6. data = data.replace(PROTECTION_PREFIX, '');
  7. if (JSON_START.test(data) && JSON_END.test(data))
  8. data = fromJson(data, true);
  9. }
  10. return data;
  11. }],
  12. // transform outgoing request data
  13. transformRequest: [function (d) {
  14. return isObject(d) && !isFile(d) ? toJson(d) : d;
  15. }],
  16. // default headers
  17. headers: {
  18. common: {
  19. 'Accept': 'application/json, text/plain, */*',
  20. 'X-Requested-With': 'XMLHttpRequest'
  21. },
  22. post: {'Content-Type': 'application/json;charset=utf-8'},
  23. put: {'Content-Type': 'application/json;charset=utf-8'}
  24. }
  25. };

注意它默认的 POST 方法出去的 Content-Type

对于几个标准的 HTTP 方法,有对应的 shortcut :

  • $http.delete(url, config)
  • $http.get(url, config)
  • $http.head(url, config)
  • $http.jsonp(url, config)
  • $http.post(url, data, config)
  • $http.put(url, data, config)

注意其中的 JSONP 方法,在实现上会在页面中添加一个 script 标签,然后放出一个 GET 请求。你自己定义的,匿名回调函数,会被 ng 自已给一个全局变量。在定义请求,作为 GET 参数,你可以使用 JSON_CALLBACK 这个字符串来暂时代替回调函数名,之后 ng 会为你替换成真正的函数名:

  1. var p = $http({
  2. method: 'JSONP',
  3. url: '/json',
  4. params: {callback: 'JSON_CALLBACK'}
  5. });
  6. p.success(function(response, status, headers, config){
  7. console.log(response);
  8. $scope.name = response.name;
  9. });

$http 有两个属性:

  • defaults 请求的全局配置
  • pendingRequests 当前的请求队列状态
  1. $http.defaults.transformRequest = function(data){console.log('here'); return data;}
  2. console.log($http.pendingRequests);

2.广义回调管理

和其它框架一样, ng 提供了广义的异步回调管理的机制。 $http 服务是在其之上封装出来的。这个机制就是 ng 的 $q 服务。

不过 ng 的这套机制总的来说实现得比较简单,按官方的说法,够用了。

使用的方法,基本上是:

  • 通过 $q 服务得到一个 deferred 实例
  • 通过 deferred 实例的 promise 属性得到一个 promise 对象
  • promise 对象负责定义回调函数
  • deferred 实例负责触发回调
  1. var TestCtrl = function($q){
  2. var defer = $q.defer();
  3. var promise = defer.promise;
  4. promise.then(function(data){console.log('ok, ' + data)},
  5. function(data){console.log('error, ' + data)});
  6. //defer.reject('xx');
  7. defer.resolve('xx');
  8. }

了解了上面的东西,再分别看 $q , deferred , promise 这三个东西。

2.1 $q

$q 有四个方法:

  • $q.all() 合并多个 promise ,得到一个新的 promise
  • $q.defer() 返回一个 deferred 对象
  • $q.reject() 包装一个错误,以使回调链能正确处理下去
  • $q.when() 返回一个 promise 对象

$q.all() 方法适用于并发场景很合适:

  1. var TestCtrl = function($q, $http){
  2. var p = $http.get('/json', {params: {a: 1}});
  3. var p2 = $http.get('/json', {params: {a: 2}});
  4. var all = $q.all([p, p2]);
  5. p.success(function(res){console.log('here')});
  6. all.then(function(res){console.log(res[0])});
  7. }

$q.reject() 方法是在你捕捉异常之后,又要把这个异常在回调链中传下去时使用:

要理解这东西,先看看 promise 的链式回调是如何运作的,看下面两段代码的区别:

  1. var defer = $q.defer();
  2. var p = defer.promise;
  3. p.then(
  4. function(data){return 'xxx'}
  5. );
  6. p.then(
  7. function(data){console.log(data)}
  8. );
  9. defer.resolve('123');
  1. var defer = $q.defer();
  2. var p = defer.promise;
  3. var p2 = p.then(
  4. function(data){return 'xxx'}
  5. );
  6. p2.then(
  7. function(data){console.log(data)}
  8. );
  9. defer.resolve('123');

从模型上看,前者是“并发”,后者才是“链式”。

而 $q.reject() 的作用就是触发后链的 error 回调:

  1. var defer = $q.defer();
  2. var p = defer.promise;
  3. p.then(
  4. function(data){return data},
  5. function(data){return $q.reject(data)}
  6. ).
  7. then(
  8. function(data){console.log('ok, ' + data)},
  9. function(data){console.log('error, ' + data)}
  10. )
  11. defer.reject('123');

最后的 $q.when() 是把数据封装成 promise 对象:

  1. var p = $q.when(0, function(data){return data},
  2. function(data){return data});
  3. p.then(
  4. function(data){console.log('ok, ' + data)},
  5. function(data){console.log('error, ' + data)}
  6. );

2.2 deferred

deferred 对象有两个方法一个属性。

  • promise 属性就是返回一个 promise 对象的。
  • resolve() 成功回调
  • reject() 失败回调
  1. var defer = $q.defer();
  2. var promise = defer.promise;
  3. promise.then(function(data){console.log('ok, ' + data)},
  4. function(data){console.log('error, ' + data)});
  5. //defer.reject('xx');
  6. defer.resolve('xx');

2.3 promise

promise 对象只有 then() 一个方法,注册成功回调函数和失败回调函数,再返回一个 promise 对象,以用于链式调用。

from :http://blog.csdn.net/violet_day/article/details/16918257

【转】angular Ajax请求的更多相关文章

  1. angular ajax请求 结果显示显示两次的问题

    angular 项目中,由于用到ajax 请求,结果显示如下情况 同样的接口,显示两次,其中第一次请求情况为 request method 显示为opttions 第二次的情况是 为啥会出现如此的情况 ...

  2. Spring Security登录超时,angular ajax请求出错自动跳转至登录页(jQuery也适用)

    公司开发采用Spring Security+AngualerJS框架,在session过期之后,ajax请求会直接出错.本文介绍如何实现出错情况下自动跳转至登录页. 整体思路是,session过期后, ...

  3. Angular和jQuery的ajax请求的差别

    近期项目中使用angular,结果发现后台没法获取參数,所以,略微研究了一下两者在发送ajax时的差别. 注意angular和jquery的ajax请求是不同的. 在jquery中,官方文档解释con ...

  4. 配置Chrome支持本地(file协议)的AJAX请求

    什么问题 WEB开发过程中,很多时候我们都是写一些简单的Demo,并不是开发一个完整项目,此时我们常见的操作是: 新建文件夹 新建需要的文件 在Sublime(或其他编辑器)中完成DEMO的编码 双击 ...

  5. 通过配置http拦截器,来进行ajax请求验证用户登录的页面跳转

    在.NET中验证用户是否登录或者是否过期,若需要登录时则将请求转向至登录页面. 这个流程在进行页面请求时是没问题的,能正确进行页面跳转. 然而在使用xmlhttprequest时,或者jq的getJs ...

  6. js 中ajax请求时设置 http请求头中的x-requestd-with= ajax

    今天发现 AngularJS 框架的$http服务提供的$http.get() /$http.post()的ajax请求中没有带 x-requested-with字段. 这样的话,后端的php 就无法 ...

  7. Form表单提交,Ajax请求,$http请求的区别

    做过前端同学想必都避免不了要和后台server打交道.而以下这三种与后台交互的方式想必大家都不陌生. Form表单提交,Ajax请求,Angular的$http请求 以前一直搞不清楚什么时候应该用哪种 ...

  8. 使用Angular2的Http发送AJAX请求

    使用Angular2的Http发送AJAX请求 Angular的文档并不详细,甚至API文档也有一些错误.经过查阅资料并经大量实验,终于明确了Angular的Http发送Ajax请求的方式方法.本文描 ...

  9. 原生js实现类的添加和删除,以及对数据的add和update、view ,ajax请求 ,页面离开的操作

    1 类操作 function hasClass(cla, element) { if(element.className.trim().length === 0) return false; var ...

随机推荐

  1. Postgresql 技巧

    备份 pg_dump -f "F:/dump.sql"<file name> -U postgres<database name> -h 10.38.197 ...

  2. 【css】 收藏 纯css打造 mackbook air

    http://www.cnblogs.com/myvin/p/4621231.html <html lang="en"> <head> <meta c ...

  3. MySQL5.5版本安装失败问题

    安装的时候前边都正常,总是到最后一步出问题.前几次是到最后一步没有响应,网上有一种方法是在安装MySQl的时候改变默认的服务名“MySQL”.但我试过这种方法,好几次都没成功. 这种情况下我用了第二种 ...

  4. [搜片神器]DHT后台管理程序数据库流程设计优化学习交流

    谢谢园子朋友的支持,已经找到个VPS进行测试,国外的服务器: sosobt.com 大家可以给提点意见... 服务器在抓取和处理同时进行,所以访问速度慢是有些的,特别是搜索速度通过SQL的like来查 ...

  5. 1046: [HAOI2007]上升序列 - BZOJ

    Description 对于一个给定的S={a1,a2,a3,…,an},若有P={ax1,ax2,ax3,…,axm},满足(x1 < x2 < … < xm)且( ax1 < ...

  6. 1018: [SHOI2008]堵塞的交通traffic - BZOJ

    Description 有一天,由于某种穿越现象作用,你来到了传说中的小人国.小人国的布局非常奇特,整个国家的交通系统可以被看成是一个2行C列的矩形网格,网格上的每个点代表一个城市,相邻的城市之间有一 ...

  7. 'vt100': unknown terminal type.

    在Linux终端执行clear或top命令时出现:vt100: unknown terminal type的错误 1.临时办法,下次启动失效,需要重新执行 执行以下命令 $ printenv | gr ...

  8. 15个带示例的jQuery滚动条插件

    1.NiceScroll:可用于桌面.移动与触摸设备的jQuery滚动插件 NiceScroll是一个jQuery插件(since 1.5),它有着类似于ios/移动设备的样式.它支持Div.iFra ...

  9. 数据聚合 & 分组:新一代系统监控的核心功能

    遥想 2015 年 8 月 17 日,Cloud Insight 还在梳理功能原型,畅想 Cloud Insight 存在的意义:为什么阿里云用户需要使用 Cloud Insight 来加强管理. 而 ...

  10. eclipse颜色配置

    Eclipse颜色主题插件:Eclipse Color Theme http://blog.sina.com.cn/s/blog_674212810101go8x.html 一个很赞的eclipse插 ...