从随机文章中获取链接

时间:2013-11-30 00:43:29

标签: javascript wikimedia

我有一个函数可以获得随机Wikipedia文章的第一部分,但我不知道如何获取该文章的实际URL。我在WikiMedia API中查看过,找不到它。

getRandomArticle : function() {
    return $.getJSON("http://en.wikipedia.org/w/api.php?action=query&generator=random&grnnamespace=0&prop=extracts&explaintext&exintro=&format=json&callback=?", function (data) {});
}

有什么想法吗?

2 个答案:

答案 0 :(得分:5)

这并不像你想象的那么容易。 API返回具有内部ID的页面,您必须再次使用API​​来获取特定页面的信息,例如URL。

$.getJSON("http://en.wikipedia.org/w/api.php?action=query&generator=random&grnnamespace=0&prop=extracts&explaintext&exintro=&format=json&callback=?", function (data) {
    $.each(data.query.pages, function(k, v) {
        $.getJSON('http://en.wikipedia.org/w/api.php?action=query&prop=info&pageids='+v.pageid+'&inprop=url&format=json&callback=?', function(url) {
            $.each(url.query.pages, function(key, page) {
                console.log(page); // contains the page data
                var url = page.fullurl; // the url to the page
            });
        });
    });
});

FIDDLE

答案 1 :(得分:1)

您的问题与What is wikipedia pageid? how to change it into real page url?类似。

最简单的方法? 只需转到http://en.wikipedia.org/?curid=pageid

如果您正在获取query.result.pageid.extract以从文章中获取文本,那么您现在是pageid。