【发布时间】:2015-09-13 08:32:03
【问题描述】:
在我的 Angular.JS 代码中,我使用 GET/JSONP 调用 Yahoo YQL API,我确实得到了响应。但是有两个问题。
- 它调用错误方法而不是成功。为什么?
- 延迟变量似乎在错误函数中未定义。为什么?
您可以找到JsFiddle here。它基于AJAX example。
function DefaultCtrl($log, $scope, $http, myService) {
var promise = myService.getSuggestions('yahoo');
promise.then(
function(payload) {
$log.info('receiving data', payload);
$scope.test = payload;
$log.info('received data', payload);
},
function(errorPayload) {
$log.error('failure loading suggestions', errorPayload);
});
}
angular.module('MyModule', [])
.factory('myService', function ($http, $log, $q) {
return {
getSuggestions: function (symbol) {
var deferred = $q.defer();
$http.jsonp("http://d.yimg.com/autoc.finance.yahoo.com/autoc", {
cache: true,
params: {
callback: "YAHOO.Finance.SymbolSuggest.ssCallback",
query: symbol
}
})
.success(function(data) {
deferred.resolve(data);
})
.error(function(msg, code) {
$log.error("error");
deferred.reject(msg); // <---- error occurs here!
$log.error(msg, code);
});
var YAHOO = window.YAHOO = {Finance: {SymbolSuggest: {}}};
YAHOO.Finance.SymbolSuggest.ssCallback = function (data) {
$log.info("received data", data);
}; // YAHOO.Finance
return deferred.promise;
}
}
});
【问题讨论】:
标签: jquery angularjs jsonp jquery-deferred q