我正在尝试按照this SO question
上的角度做这个家伙说过的事情他的代码经过:
.controller('WikiQueryCtrl', ['$scope', '$http', function($scope, $http) {
$http({
//these geo coordinates and the date ranges will eventually be dynamic.
url: 'https://wdq.wmflabs.org/api?q=AROUND[625,-25.911389,31.957222,5]%20AND%20BETWEEN[585,1985,1987]&callback=JSON_CALLBACK',
method: 'jsonp'
})
.success(function(response) {
var items = response.items;
$scope.jason = items;
var wikiDataString = 'http://www.wikidata.org/w/api.php?action=wbgetentities&format=json&ids=Q' + items + '&props=sitelinks%7Csitelinks%2Furls&callback=JSON_CALLBACK';
$http({
url: wikiDataString,
method: 'jsonp'
})
.success(function(response2) {
$scope.jason2 = response2;
var url = response2.entities["Q" + items].sitelinks.enwiki.url;
var wikipediaTitle = url.substr(24, url.length);
var wikipediaURL = 'http://en.wikipedia.org/w/api.php?action=query&prop=extracts|info&exintro&titles=' + wikipediaTitle + '&format=json&explaintext&redirects&inprop=url&indexpageids&format=json&callback=JSON_CALLBACK';
$http({
url: wikipediaURL,
method: 'jsonp'
}).success(function(response4) {
var query = response4.query;
var pageID = response4.query.pageids;
var title = response4.query.pages[pageID].title;
var fullurl = response4.query.pages[pageID].fullurl;
var content = response4.query.pages[pageID].extract;
$scope.title = title;
$scope.content = content;
$scope.fullurl = fullurl;
$scope.jason = query;
});
});
});
}]);
我知道维基百科有一个geosearch但不是一个日期范围,我试着看看wikidata这个人已经完成并将其转换为jQuery但没有正面结果,这里是一个代码笔:
https://codepen.io/anon/pen/PjywjR
我将如何在jQuery中实现使用Angular实现的目标,通过坐标和日期范围搜索维基百科内容。
答案 0 :(得分:0)
我没有使用维基百科API,而网址https://wdq.wmflabs.org在浏览器和AJAX请求中都给了我502代码。所以第一个问题是:你确定这是一个有效的API端点吗?
接下来,我会在您测试和调试时简化您的AJAX请求:
var url = "https://wdq.wmflabs.org/api";
var data = {
q: "AROUND[625,-25.911389,31.957222,5]%20AND%20BETWEEN[585,1985,1987]",
callback: "JSON_CALLBACK"
};
$.ajax({
dataType: "jsonp",
url: url,
data: data,
success: function(data) {
console.log(data);
}
});
如上所述,此请求目前收到502 Bad Gateway响应。