首页 > 解决方案 > 如何在第二个 ajax 调用之外获得价值

问题描述

我有两个 API 调用:

  1. 第一个 API 调用获取 ISBN 列表。

  2. 第二个 API 调用从第一步中的 ISBN 列表中获取每个 ISBN 的信息。

第 1 步中的列表可能包含 50 个 ISBN,但在第 2 步检查每个 ISBN 的信息时,如果缺少某些信息,我不想显示或计算该 ISBN。

我的最终目标是用完整的信息计算我拥有的 ISBN 总数,但由于 Ajax 是异步的,我看不到检索它。

let request = new XMLHttpRequest();
request.open("GET",requestHTML,true)
request.send();

request.onload = parseXML;

function parseXML(){
    const xmlText = request.responseText;
    const parser = new DOMParser();
    const xmlDoc = parser.parseFromString(xmlText,"text/xml");

    var isbns = xmlDoc.getElementsByTagName("isbn");

    let counter = 0;
    for(isbn of isbns){
        let isbnString = isbn.textContent;
        let isbnURL = `https://openlibrary.org/api/books?jscmd=data&format=json&bibkeys=ISBN:${isbnString}`;
        $.ajax({            
            type: 'GET',
            url: isbnURL,
            dataType: 'json',
            success: function(result){
                    ...
                    if(hasAllInfo){
                        $("#content_container").append(`<div class="book_container" id="${bookid}">`);
                        ...
                    }
                        counter ++;
            },
            error: function(){
                console.log('ERROR');
            }
        })
    }
}
console.log("Total books found with all information:" + counter);

我希望最后一行显示找到的包含所有信息的 ISBN 总数,但我得到 0

标签: javascriptajaxasynchronous

解决方案


它非常接近,您只需console.logcounter.

let request = new XMLHttpRequest();
request.open("GET",requestHTML,true)
request.send();

request.onload = parseXML;

function parseXML(){
    const xmlText = request.responseText;
    const parser = new DOMParser();
    const xmlDoc = parser.parseFromString(xmlText,"text/xml");

    var isbns = xmlDoc.getElementsByTagName("isbn");

    let counter = 0;
    for(isbn of isbns){
        let isbnString = isbn.textContent;
        let isbnURL = `https://openlibrary.org/api/books?jscmd=data&format=json&bibkeys=ISBN:${isbnString}`;
        $.ajax({            
            type: 'GET',
            url: isbnURL,
            dataType: 'json',
            success: function(result){
                    ...
                    if(hasAllInfo){
                        $("#content_container").append(`<div class="book_container" id="${bookid}">`);
                        ...
                    }
                    // changes here
                    if(++counter === isbns.length){
                      console.log("Total books found with all information:" + counter);
                    }
            },
            error: function(){
                console.log('ERROR');
            }
        })
    }
}

推荐阅读