angular 為了解決跨域問題 一些第三方接口會提供jsonp來調用,需要使用callback=JSON_CALLBACK來處理
這個時候問題來了,有些借口是不支持callback里面帶有點語法的,最典型的就是豆瓣了,而callback=JSON_CALLBACK 會被 angular轉換成 callback = angular.callbacks._[id]這種形式,
這個時候就會報錯了,因為返回的是json格式而不是jsonp格式。為了解決這類問題最簡單的方法肯定是重定義方法名,我在這里就是采用這種方法的,但是我們應該怎么改名字呢?答案就是在http攔截器里面,詳情看代碼。
https://api.douban.com/v2/book/isbn/' + isbn + "/reviews?callback=JSON_CALLBACK"
.factory("httpInterceptor", ["App", "$rootScope", '$injector','$timeout', function (App, $rootScope, $injector,$timeout) {return {
request: function (config) {
if (config.method === 'JSONP') {
console.log(config);
var callbackId = angular.callbacks.counter.toString(36);
config.callbackName = 'angular_callbacks_' + callbackId;
config.url = config.url.replace('JSON_CALLBACK', config.callbackName);
$timeout(function () {
window[config.callbackName] = angular.callbacks['_' + callbackId];
}, 0, false);
}
if (!config.isLoading) {
count++;
$rootScope.$broadcast('loading:show')
}
return config || App.q.when(config);
},
requestError: function (rejection) { return App.q.reject(rejection)
},
response: function (response) {
return response || App.q.when(response);
},
responseError: function (rejection) {// do something on response error
return App.q.reject(rejection);
}
}
}])
就是以上代碼進行方法名更改了。
以上思路來源於 http://stackoverflow.com/questions/25400891/how-to-custom-set-angularjs-jsonp-callback-name
