- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个请求函数:
function search(request) {
return $http.post('/path/to/resource', request);
}
我可以这样调用它:
search({/*...*/})
.success(function() {})
.error(function() {})
因为我经常需要通过ID来查找一些对象,所以我需要一个快捷功能。我找不到如何创建此函数,以便我也可以将它与 success()
和 error()
函数链接起来。
我搜索了如何在 Angular 中创建 promise 并找到了 documentation about $q这就是我尝试过的:
function searchById(id) {
var deferred = $q.defer();
search({id: id}).
then(function (response) {
deferred.resolve(response.data.results[0]);
}, function (error) {
deferred.reject(error);
});
return deferred.promise;
}
我只能这样调用它:
searchById().then(successCallback, errorCallback);
我希望能够这样调用它:
searchById()
.success(successCallback)
.error(errorCallback);
关于 $q
的文档表明它返回一个 promise
而关于 $http
的文档表明它返回一个 httpPromise
但我不知道如何创建 httpPromise
。
有什么想法吗?
最佳答案
在 Angular promise 中,错误回调应该是捕获而不是错误,试试这个
searchById()
.then(successCallback)
.catch(errorCallback);
sjokkogutten 是正确的,在这种情况下你不需要使用 $q 你可以简化这个
var deferred = $q.defer();
search({id: id}).
then(function (response) {
deferred.resolve(response.data.results[0]);
}, function (error) {
deferred.reject(error);
});
return deferred.promise;
对此
return search({id: id}).
then(function (response) {
return response.data.results[0];
}
关于javascript - Angular httpPromise,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36986464/
我有一个请求函数: function search(request) { return $http.post('/path/to/resource', request); } 我可以这样调用它
我正在尝试从 yahoo 的 api 获取股票报价,并且正在使用 angular 的 $http.jsonp 方法。目标是当结果返回时,让应用程序转到这条路线:'/stocks/show_stock'
根据AngularJS doc ,调用 $http 返回以下内容: Returns a promise object with the standard then method and two htt
我是一名优秀的程序员,十分优秀!