正在从随机文章中获取链接

Getting link from random article

本文关键字:获取 链接 文章 随机      更新时间:2023-12-13

我有一个函数可以获取一篇随机维基百科文章的第一部分,但我不知道如何获取该文章的实际URL。我在维基媒体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) {});
}

有什么想法吗?

这并不像你想象的那么容易。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

您的问题类似于什么是wikipedia pageid?如何将其更改为真实的页面url?。

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

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