须要在 angular 中掌握异步的知识,咱们须要掌握这几个重要的知识点,
http, promisejavascript
首先来看看 $q 的基本含义:java
$q
服务的到一个 deferred
deferred
实例的 promise 属性获得一个 promise 对象angular.module('app', [], angular.noop)
.controller('TestCtrl', function($scope){
var defer = $q.defer();
var promise = defer.promise;
promise.then(function(data){console.log('ok, ' + data)},
function(data){console.log('error, ' + data)});
//defer.reject('xx');
defer.resolve('xx');
});
复制代码
了解了上面的东西,再分别看 $q , deferred , promise 这三个东西。json
$q
有四种方法
$q.all
适用于并发的场景angular.module('app', [], angular.noop)
.controller('TestCtrl', function($scope){
var p = $http.get('/json', {params: {a: 1}});
var p2 = $http.get('/json', {params: {a: 2}});
var all = $q.all([p, p2]);
p.success(function(res){console.log('here')});
all.then(function(res){console.log(res[0])});
});
复制代码
$q.reject()
方法是在你捕捉异常以后,又要把这个异常在回调链中传下去时使用:要理解这东西,先看看 promise 的链式回调是如何运做的,看下面两段代码的区别:api
var defer = $q.defer();
var p = defer.promise;
p.then(
function(data){return 'xxx'}
);
p.then(
function(data){console.log(data)}
);
defer.resolve('123');
var defer = $q.defer();
var p = defer.promise;
var p2 = p.then(
function(data){return 'xxx'}
);
p2.then(
function(data){console.log(data)}
);
defer.resolve('123');
复制代码
从模型上看,前者是“并发”,后者才是“链式”。promise
而 $q.reject() 的做用就是触发后链的 error 回调:bash
var defer = $q.defer();
var p = defer.promise;
p.then(
function(data){return data},
function(data){return $q.reject(data)}
).
then(
function(data){console.log('ok, ' + data)},
function(data){console.log('error, ' + data)}
)
defer.reject('123');
//最后的 $q.when() 是把数据封装成 promise 对象:
var p = $q.when(0, function(data){
return data
},function(data){return data});
p.then(
function(data){
console.log('ok, ' + data)
},
function(data){
console.log('error, ' + data)
}
);
复制代码
promise 属性就是返回一个 promise 对象的。 resolve() 成功回调 reject() 失败回调并发
var defer = $q.defer();
var promise = defer.promise;
promise.then(function(data){console.log('ok, ' + data)},
function(data){console.log('error, ' + data)});
//defer.reject('xx');
defer.resolve('xx');
复制代码